SpringBoot @RequestBody 中文乱码

今天忽然想学习一下Restful风,详细的我就不赘述了,个人理解是同一个请求路径根据请求方式不一样进行不一样的处理javascript

如四种提交方式,这里推荐一个插件Postman,能够模仿各类请求类型,自行百度安装吧php

GET(SELECT):从服务器查询,能够在服务器经过请求的参数区分查询的方式。  
POST(CREATE):在服务器新建一个资源,调用insert操做。  
PUT(UPDATE):在服务器更新资源,调用update操做。  
DELETE(DELETE):从服务器删除资源,调用delete语句

 

下面进行实践html

前端简易代码前端

<a href="#" onclick="add()">添加</a>
<a href="#" onclick="del()">删除</a>
<a href="#" onclick="select()">查询</a>
<a href="#" onclick="update()">修改</a>

<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
<script type="text/javascript">
    function add(){
    var id = "111111111";
        $.ajax({
            type:"POST",
            url:"test.do",
            data:{id:"添加11111111111"}});
    }


    function del(){
   var id = "2222222";
        $.ajax({
            type:"DELETE",
            url:"test.do",
            data:{id:"删除22222222222"},
            contentType : "text/html;charset=UTF-8",
            dataType:"json"});
    }

     function select(){
    var id = "33333";
        $.ajax({
            type:"GET",
            url:"test.do",
            data:{id:"查询3333333333"}});
    }

     function update(){
    var id = "111111111";
        $.ajax({
            type:"PUT",
            url:"test.do",
            data:{id:"修改4444444"}});
    }
</script>

后台简易代码java

@RequestMapping(value = "/test.do", method = RequestMethod.DELETE)
    public void test(String id){
        System.out.println("删除");
        System.out.println(id);
    }

    @RequestMapping(value = "/test.do", method = RequestMethod.POST)
    public void test1(String id){
        System.out.println("添加");
        System.out.println(id);
    }

    @RequestMapping(value = "/test.do", method = RequestMethod.PUT)
    public void test2(String id){
        System.out.println("修改");
        System.out.println(id);
    }

    @RequestMapping(value = "/test.do", method = RequestMethod.GET)
    public void test3(String id){
        System.out.println("查询");
        System.out.println(id);
    }

前台ajax的提交方式对应于后台@RequestMapping(value = "/test.do", method = RequestMethod.方式)jquery

控制台:web

添加
添加11111111111
2018-10-26 09:28:45.325 DEBUG 8500 --- [nio-8080-exec-4] o.s.b.w.f.OrderedRequestContextFilter    : Cleared thread-bound request context: org.apache.catalina.connector.RequestFacade@718e55d2
2018-10-26 09:28:45.977 DEBUG 8500 --- [nio-8080-exec-8] o.s.b.w.f.OrderedRequestContextFilter    : Bound request context to thread: org.apache.catalina.connector.RequestFacade@718e55d2
删除
null
2018-10-26 09:28:45.984 DEBUG 8500 --- [nio-8080-exec-8] o.s.b.w.f.OrderedRequestContextFilter    : Cleared thread-bound request context: org.apache.catalina.connector.RequestFacade@718e55d2
2018-10-26 09:28:46.731 DEBUG 8500 --- [nio-8080-exec-9] o.s.b.w.f.OrderedRequestContextFilter    : Bound request context to thread: org.apache.catalina.connector.RequestFacade@718e55d2
查询
查询3333333333
2018-10-26 09:28:46.734 DEBUG 8500 --- [nio-8080-exec-9] o.s.b.w.f.OrderedRequestContextFilter    : Cleared thread-bound request context: org.apache.catalina.connector.RequestFacade@718e55d2
2018-10-26 09:28:47.585 DEBUG 8500 --- [nio-8080-exec-5] o.s.b.w.f.OrderedRequestContextFilter    : Bound request context to thread: org.springframework.web.filter.HttpPutFormContentFilter$HttpPutFormContentRequestWrapper@535448c
修改
修改4444444
2018-10-26 09:28:47.590 DEBUG 8500 --- [nio-8080-exec-5] o.s.b.w.f.OrderedRequestContextFilter    : Cleared thread-bound request context: org.springframework.web.filter.HttpPutFormContentFilter$HttpPutFormContentRequestWrapper@535448c

可见Restful已经根据不一样的提交方式进入不一样的方法了,后面你们就能够自行处理了,可是还有一个问题,当提交方式为DELETE时,接收的id值为nullajax

在参数列表中加入@RequestBody注解,这里的做用是经过@requestBody能够将请求体中的JSON字符串绑定到相应的bean上,也能够将其分别绑定到对应的字符串上。spring

 @RequestMapping(value = "/lll.do", method = RequestMethod.DELETE)
    public void test(@RequestBody String id){
        System.out.println("删除");
        System.out.println(id);
    }

控制台:apache

2018-10-26 10:31:09.661 DEBUG 2720 --- [nio-8080-exec-1] o.s.b.w.f.OrderedRequestContextFilter    : Bound request context to thread: org.apache.catalina.connector.RequestFacade@4bafd197
删除
id=%E5%88%A0%E9%99%A422222222222
2018-10-26 10:31:09.667 DEBUG 2720 --- [nio-8080-exec-1] o.s.b.w.f.OrderedRequestContextFilter    : Cleared thread-bound request context: org.apache.catalina.connector.RequestFacade@4bafd197

能够看到,是能够获取到数据了,可是会出现中文乱码,这个中文乱码超级顽固,设置了不少都没用,最后在前台这样设置就能够了

 function del(){
   var id = "删除sssss22222222222";
        $.ajax({
            type:"DELETE",
            url:"lll.do",
            data:JSON.stringify(id),
            contentType :"application/json",
            dataType:"json"});
    }

JSON.stringify() 方法用于将 JavaScript 值转换为 JSON 字符串。

这样控制台的输出就变成了:

2018-10-26 13:42:59.585 DEBUG 8364 --- [nio-8080-exec-7] o.s.b.w.f.OrderedRequestContextFilter    : Bound request context to thread: org.apache.catalina.connector.RequestFacade@343dbcb6
删除
"删除sssss22222222222"
2018-10-26 13:42:59.587 DEBUG 8364 --- [nio-8080-exec-7] o.s.b.w.f.OrderedRequestContextFilter    : Cleared thread-bound request context: org.apache.catalina.connector.RequestFacade@343dbcb6

 为何参数变成字符串就不乱码了呢?原来@RequestBody主要用来接收前端传递给后端的json字符串中的数据的,注意必定是字符串

这里给出JSON字符串和JSON对象的区别

JSON字符串
var data ='{"id":"删除sssss22222222222"}';//字符串是单引号或者双引号引发来的

JSON对象
var data ={"id":"删除sssss22222222222"};

全部上面的JSON.stringify()还能够改为声明成JSON字符串传输

JSON对象转JSON字符串能够用JSON.stringify()方法

反过来JSON字符串转JSON对象能够用JSON.parse()方法

$.ajax({
url : 'login.php',
type : 'post',
data : {id:id,name:name}, //这里是json对象
success : function(data){......}
)};
默认是以application/x-www-form-urlencoded方式提交。也就是常见的表单提交方式

若是使用ajax的application/json方式,记得data参数是字符串类型的。使用JSON.stringify()转换一下

 至于何时用@RequestBody呢?

GET、POST方式提时, 根据request header Content-Type的值来判断: 
application/x-www-form-urlencoded, 可选(即非必须,由于这种状况的数据@RequestParam, @ModelAttribute也能够处理,固然@RequestBody也能处理); 
multipart/form-data, 不能处理(即便用@RequestBody不能处理这种格式的数据); 
其余格式, 必须(其余格式包括application/json, application/xml等。这些格式的数据,必须使用@RequestBody来处理)。
相关文章
相关标签/搜索