一. JSON
关于JSON,可以看老蝴蝶以前的文章: JSON简介及前端简单解析(一)
二. SpringMVC对JSON的处理
SpringMVC 对JSON的处理,主要是通过 @RequestBody 和@ResponseBody 两个注解进行的。
SpringMVC中默认的JSON转换使用的是 jackson, 所用的类是 MappingJackson2HttpMessageConverter . 故需要先下载jackson.jar 包。
有两种形式。 借鉴网上的图片,老蝴蝶重新画了一下。为了加深印象。
最常用的是第二种, key/value 的形式。
二.一 下载后导入 jackson有关的jar包。
把这几个jackson 的jar包都引入进来,否则会类找不到的错误。
如:
二.二 springMVC配置文件 springmvc.xml 写原先的映射器和适配器
<!-- 先用以前的复杂形式 --> <!-- 处理器映射器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean> 处理器适配器 <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"> <property name="messageConverters"> <list> <!--可添加其他的转换器--> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"></bean> </list> </property> </bean>
二.三 后端处理JSON (原始的方式) ,返回值为 void
@RequestMapping(value="toLogin") public String toLogin(){ return "user/login"; } @RequestMapping(value="/voidJson") public void getJsonUser(@RequestBody User user,HttpServletResponse response){ System.out.println("前台传过来的值是:"+user.toString()); //以void的形式返回 response.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=utf-8"); ObjectMapper object=new ObjectMapper(); user.setName("我是老蝴蝶"); //改变前台传过来的值 user.setId(1); //添加新的属性值 try { System.out.println("输出值为:"+object.writeValueAsString(user)); response.getWriter().println(object.writeValueAsString(user)); } catch (JsonGenerationException e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } catch (JsonMappingException e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } catch (IOException e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } }
二.四 前台传入json ,注意路径和返回数据类型
<body> <h2>两个蝴蝶飞欢迎你</h2> <span id="name"></span> <br> <span id="sex"></span> <br> <span id="description"></span> <br> <span id="id"></span> <br> <button onclick="execVoidJSON()">执行voidjson</button> <script type="text/javascript"> function execVoidJSON(){ //1。 定义对象 var user={"name":"两个蝴蝶飞","sex":24,"description":"一个快乐的程序员"}; //2。 执行ajax程序 $.ajax({ type:"post", contentType:"application/json;charset=utf-8", url:"voidJson.action", //注意请求路径 data:JSON.stringify(user), success:function(data){ //接收过来的是字符串 var jsonData=JSON.parse(data); $("#name").html(jsonData.name); $("#sex").html(jsonData.sex); $("#description").html(jsonData.description); $("#id").html(jsonData.id); } }) } </script> </body>
二.五 运行服务器,测试结果
点击 按钮, 控制台打印输出
前台页面展示,
响应数据类型
还需要将 json字符串转换成json数据,太麻烦。
下面,开始进行相应的优化。
二.六 springmvc.xml 配置文件优化
直接将 二.二 步骤中的内容转换成
<!-- 适配器和映射器简写 --> <mvc:annotation-driven></mvc:annotation-driven>
即可。 会自动注入 json 转换器。 一般开发中常用这种形式。
二.七 利用@ResponseBody 注解进行将java 对象转换成 json串,返回值为java 对象。
@RequestMapping(value="toLogin") public String toLogin(){ return "user/login"; } @RequestMapping(value="/responseJson") public @ResponseBody User getResponseUser(@RequestBody User user){ System.out.println("前台传过来的值是:"+user.toString()); user.setName("我是老蝴蝶"); //改变前台传过来的值 user.setId(1); //添加新的属性值 return user; //很简单的写法。 }
二.八 前台传入json
<body> <h2>两个蝴蝶飞欢迎你</h2> <span id="name"></span> <br> <span id="sex"></span> <br> <span id="description"></span> <br> <span id="id"></span> <br> <button onclick="execResponseJSON()">执行Responsejson</button> <script type="text/javascript"> function execResponseJSON(){ //1。 定义对象 var user={"name":"两个蝴蝶飞","sex":24,"description":"一个快乐的程序员"}; //2。 执行ajax程序 $.ajax({ type:"post", contentType:"application/json;charset=utf-8", url:"responseJson.action", //注意请求路径 data:JSON.stringify(user), success:function(data){ //可直接使用data $("#name").html(data.name); $("#sex").html(data.sex); $("#description").html(data.description); $("#id").html(data.id); } }) } </script> </body>
二.九 运行服务器,进行查看
控制台打印输出:
前台数据展示:
响应数据类型
上面就是 请求 json字符串的形式。 当然,响应的时候,也可以响应集合。 这个在下面讲解。