Spring MVC的jQuery的+ Ajax的显示406错误?(Spring MVC + Jqu

2019-10-29 14:17发布

我寻觅了很多,不能找到一个solution.Similar线程也是我们的堆栈overflow.But没有use.So我创建了一个新的线程。

我的JSP是,

<boby>
<% System.out.println("request.getContextPath() : "+request.getContextPath()); %>
<h1>Spring_JsonTest Example</h1>
    <table>
        <tr><td colspan="2"><div id="error" class="error"></div></td></tr>
        <tr><td>Enter your name : </td><td> <input type="text" id="name"><br/></td></tr>
        <tr><td>Your Education : </td><td> <input type="text" id="education"><br/></td></tr>
        <tr><td colspan="2"><input type="button" value="Add Users" onclick="doAjaxPost()"><br/></td></tr>
        <tr><td colspan="2"><div id="info" class="success"></div></td></tr>
    </table>    
</body>

我jQuery是,

function doAjaxPost() {  
      // get the form values  
      var name = $('#name').val();
      var education = $('#education').val();

      $.ajax({  
        type: "POST",  
        url: contexPath + "/AddUser.html",  
        data: "name=" + name + "&education=" + education,
        success: function(response){
          // we have the response 
          if(response.status == "SUCCESS"){
          userInfo = "<ol>";
          for( i =0 ; i < response.result.length ; i++){
              userInfo += "<br><li><b>Name</b> : " + response.result[i].name + 
              ";<b> Education</b> : " + response.result[i].education;
          }
          userInfo += "</ol>";
          $('#info').html("User has been added to the list successfully. " + userInfo);
          $('#name').val('');
              $('#education').val('');
              $('#error').hide('slow');
              $('#info').show('slow');
          }else{
          errorInfo = "";
          alert("Success response : "+response)
          for( i =0 ; i < response.result.length ; i++){
              errorInfo += "<br>" + (i + 1) +". " + response.result[i].code;
          }
          $('#error').html("Please correct following errors: " + errorInfo);
          $('#info').hide('slow');
          $('#error').show('slow');
          }       
        },  
        error: function(xhr, ajaxOptions, thrownError)
            alert("status :"+xhr.status+"\nthrownError : "+thrownError+"\nresponseText : "+xhr.responseText);
            alert('Error: ' +xhr.description);  
        } 
      });  
    }  

我的控制器是,

@Controller
public class UserController {
    private List<User> userList = new ArrayList<User>(); 

    @RequestMapping(value="/AddUser.html",method=RequestMethod.POST)
    public @ResponseBody JsonResponse addUser(@ModelAttribute(value="user") User user, BindingResult result ){
        System.out.println("Add user POST method");
        JsonResponse res = new JsonResponse();
        ValidationUtils.rejectIfEmpty(result, "name", "Name can not be empty.");
        ValidationUtils.rejectIfEmpty(result, "education", "Education not be empty");
        if(!result.hasErrors()){
            userList.add(user);
            res.setStatus("SUCCESS");
            res.setResult(userList);
        }else{
            res.setStatus("FAIL");
            res.setResult(result.getAllErrors());
        }

        return res;
    }

}

我JsonResponse.java是,

package com.tps.jsonTest.service;

public class JsonResponse {
    private String status = null;
    private Object result = null;
    public String getStatus() {
        return status;
    }
    public void setStatus(String status) {
        this.status = status;
    }
    public Object getResult() {
        return result;
    }
    public void setResult(Object result) {
        System.out.println("Result : "+result.toString());
        this.result = result;
    }

}

和我User.java是,

package com.tps.jsonTest.service;

public class User {

    private String name = null;
    private String education = null;

    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getEducation() {
        return education;
    }
    public void setEducation(String education) {
        this.education = education;
    }

}

在我的控制台,

Add user POST method
Name : Anand
Education : B.E
Result : [com.tps.jsonTest.service.User@df2940]

我已经使用JAR文件,

commons-logging-1.1.1.jar
jackson-core-asl-1.9.12.jar
jackson-mapper-asl-1.9.12.jar
log4j-1.2.9.jar
servlet-api-2.4.jar
spring-aop-3.2.2.RELEASE.jar
spring-beans-3.2.2.RELEASE.jar
spring-context-3.2.2.RELEASE.jar
spring-context-support-3.2.2.RELEASE.jar
spring-core-3.2.2.RELEASE.jar
spring-expression-3.2.2.RELEASE.jar
spring-web-3.2.2.RELEASE.jar
spring-webmvc-3.2.2.RELEASE.jar

在浏览器中的错误是,

我不能使用jQuery解析对象和其移动的error.Hope我们栈的用户会帮助我。

好的答案肯定是appreciated.Thank你。

Answer 1:

这是在Spring 3.2.2或3.2.3或3.2.4的问题。 我曾尝试在Spring 3.0.0同样的例子和Spring 3.1.4这是工作的罚款。 因此,改变弹簧罐子和给予一试。

问候马杜



Answer 2:

我遇到过同样的问题。 我使用Spring 3.2作为UrlBasedViewResolver。

对于所有Ajax调用这是给406我试图改变标题,所有的dataType上述解决方案,但毫无效果。 然后我发现杰克逊罐子丢失。 我下面加2罐,它开始为我工作的罚款。

杰克逊核心ASL-1.9.4.jar杰克逊映射器-ASL-1.9.4.jar



Answer 3:

您的问题是,内容类型的响应是不能接受的请求。

你的Ajax调用没有指定dataType ,所以jQuery的推断根据网址扩展的反应应该是内容类型text/html ,但您的服务器不知道如何将一个POJO转换成HTML!

该解决方案应该是简单地添加dataType='json'到你的Ajax调用。

希望这可以帮助。



Answer 4:

既然你做一个POST ,那么你的数据不应该在查询字符串格式。 通为一个JSON对象data参数来代替。

data:{name: name, 
      education: education}


文章来源: Spring MVC + Jquery Ajax shows 406 error?