2

进行 ajax 调用后,我收到错误 405 方法不允许。我正在使用 Spring 3.0.1,Spring-web 3.0.1。

这是控制器映射

@Controller 公共类 AjaxController {

@RequestMapping(value = "/ajaxaction",
       method = RequestMethod.POST,
                 headers ="content-type=application/json")
public @ResponseBody Collection<Employee> serveAjaxRequest(@RequestBody ReqParam reqParam){
    List<Employee> empList = new ArrayList<Employee>();
    System.out.println("Req obj:: " + reqParam.getA() + " " + reqParam.getB()
            + " " + reqParam.getC() + " " + reqParam.getD() + " " + reqParam.getE());
    Employee e1 = new Employee();
    e1.setFirstName("Vaibhav");
    e1.setLastName("Raj");
    e1.setEmail("vraj3@sapient.com");
    e1.setTelephone("1111111111");
    e1.setReturnMessage("Message one!!");
    Employee e2 = new Employee();
    e1.setFirstName("Ajay");
    e1.setLastName("Singh");
    e1.setEmail("asingh@gmail.com");
    e1.setTelephone("2222222222");
    e1.setReturnMessage("Message two!!");
    empList.add(e1);
    empList.add(e2);
    return empList;
}

)

和ajax调用的Jquery代码:

功能:提交Ajax(){

$('#g').bind('click', function(evt) {
 alert($('form').serialize());
 formData = $('form').serialize();
 $.ajax({
 url: "/ajaxaction.html",
 type: 'POST',
 dataType: 'json',
 data: formData,
 success: function(data) {
          alert(data);
          },
 error: function(){
    alert("Error!!");
    }
   });

});
4

5 回答 5

0

当使用来自 Spring 控制器的 JSON 响应时,您需要定义 Accept 标头。默认情况下,Spring 将 Accept 标头定义为 html。添加标题:

headers = "Accept=application/json"

修改您的方法注释并将其更改为:

@RequestMapping(value = "/ajaxaction",
       method = RequestMethod.POST,
                 headers ="Accept:*/*")
public @ResponseBody Collection<Employee> serveAjaxRequest(@RequestBody ReqParam reqParam)
于 2012-12-12T09:42:46.723 回答
0

从错误中可以看出,这可能是您的问题:

@RequestMapping(value = "/ajaxaction", method = RequestMethod.POST, headers="content-type=application/json")

您可以使用 firebug 检查请求标头。是否有“内容类型”的标题?

于 2012-12-12T09:39:58.370 回答
0

尝试使用 contentType: 'application/json'ajax 选项设置请求内容类型。

$('#g').bind('click', function(evt) {
alert($('form').serialize());
formData = $('form').serialize();
$.ajax({
url: "/ajaxaction.html",
type: 'POST',
dataType: 'json',
data: formData,
contentType: 'application/json',
success: function(data) {
      alert(data);
      },
error: function(){
  alert("Error!!");
  }
   });

});
于 2012-12-12T09:41:27.540 回答
0

嗨,我遇到了同样的错误,我通过将 Ajax 调用从 get 更改为 post 来解决此问题,因为我在 @RequestMapping 注释中提到的方法为 RequestMethod.POST 与您相同。

但我正在调用该方法。检查你的ajax调用

于 2015-06-29T12:12:30.773 回答
0

为 RESTful Web 服务启用跨域请求,从这里获取帮助

于 2016-11-13T13:42:51.033 回答