继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

SpringMVC传递JSON数据的推荐方式

慕勒551688
关注TA
已关注
手记 250
粉丝 39
获赞 133

一、前后端传递和接受json数据

1. 使用Ajax默认格式来传递数据【推荐】

Ajax的默认格式为:application/x-www-form-urlencoded,相当于(username="admin"&password=123)来传递数据(这是GET请求的固定格式)

前端代码:

当Ajax以默认格式上传时,data数据直接使用JSON对象user,不用转换为JSON字符串(很方便) var user= {                "username" : username,                "password" : password,                "rememberMe":rememberMe            };$.ajax({    url : "http://...../jsontest.do",    type : "POST",    async : true,    data : user,    dataType : 'json',    success : function(data) {    }});

后端使用@RequestParam注解或省略:

【推荐】//直接省略注解@RequestMapping("/jsontest.do")public void test(User user,String username,String password,Boolean rememberMe){    System.out.println(user);    System.out.println("username: " + username);    System.out.println("password: " + password);    System.out.println("rememberMe: " + rememberMe);}【不推荐】//加上注解@RequestMapping("/jsontest.do")public void test(@RequestParam String username,@RequestParam String password,@RequestParam Boolean rememberMe,){    System.out.println("username: " + username);    System.out.println("password: " + password);    System.out.println("rememberMe: " + rememberMe);}

优点:  
1.前端传递数据不用转换为json字符串:JSON.stringify(user)  
2.后端接受的参数很灵活,即可以封装为User对象,亦可以使用单个参数username,rememberMe,甚至User对象和单个rememberMe参数混合使用都可以

2. 使用application/json格式来传递数据

Content-Type使用application/json的时候,要将JSON对象转换为JSON字符串  

前端代码:

var user= {                "username" : username,                "password" : password          };$.ajax({        url : "http://...../jsontest.do",        type : "POST",        async : true,        contentType: "application/json; charset=utf-8",        data : JSON.stringify(user),        dataType : 'json',        success : function(data) {        } });

后端必须使用@RequestBody 注解:

//这种方式下所有的参数都只能封装在User对象中,不能单独设置参数@RequestMapping("/jsontest")public void test(@RequestBody User user  ){    String username = user.getUsername();    String password = user.getPassword();}或者@RequestMapping("/jsontest")public void test(@RequestBody Map map  ){    String username = map.get("username").toString();    String password = map.get("password").toString();}或者 public void test(@RequestBody String jsonData) {    JSONObject jsonObject = JSON.parseObject(jsonData);    String username= jsonObject.getString("username");    String username= jsonObject.getString("password"); }

缺点:  
1.前端需要使用JSON.stringify()将JSON对象转换为JSON字符串  
2.后端在接受参数的时候比较麻烦,没有第1种简单,也没有第一种灵活

二、 spring-web.xml中需要如下配置

 <!-- annotation-driven 控制器映射器和控制器适配器 ,用来控制@Controller处理http请求的方式-->    <mvc:annotation-driven>        <mvc:message-converters><!-- register-defaults="true"表示使用默认的消息转换器 -->            <!-- FastJson(Spring4.2x以上版本设置) -->            <!-- 使用@responsebody注解并且返回值类型为String时,返回的string字符串带有双引号"{'user':'songfs'}",其原因是直接将string类型转成了json字符串,应该在json解析器之前添加字符串解析器-->            <bean class="org.springframework.http.converter.StringHttpMessageConverter"/>            <!-- FastJsonHttpMessageConverter4 使@ResponseBody支持返回Map<String,Object>等类型,它会自动转换为json-->            <!-- 需要返回json时需要配置 produces = "application/json"。不需要再指定utf-8了 -->            <bean id="fastJsonHttpMessageConverter" class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter4">                <!-- 加入支持的媒体类型 -->                <property name="supportedMediaTypes">                    <list>                        <!-- 这里顺序不能反,一定先写text/html,不然IE执行AJAX时,返回JSON会出现下载文件 -->                        <value>text/html;charset=UTF-8</value>                        <value>application/json;charset=UTF-8</value>                        <value>application/xml;charset=UTF-8</value>                    </list>                </property>                <property name="fastJsonConfig">                    <bean class="com.alibaba.fastjson.support.config.FastJsonConfig">                        <property name="features">                            <list>                                <value>AllowArbitraryCommas</value>                                <value>AllowUnQuotedFieldNames</value>                                <value>DisableCircularReferenceDetect</value>                            </list>                        </property>                        <property name="dateFormat" value="yyyy-MM-dd HH:mm:ss"/>                    </bean>                </property>            </bean>        </mvc:message-converters>    </mvc:annotation-driven>

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP