SpringMVC json数据交互
1.为何使用json作为数据交互手段
1.json数据格式简单,具有较强的可读性。
2.方便客户端解析
2.比较差异
1.请求中包含前端封装的json串,这种方式不太方便(需要前端进行json数据封装)
2.响应json串给前端 比较常用
3.非json请求: contentType: application/x-www-form-unlencoded
json请求: contentType: application/json
3.环境配置,引入jar包
SpringMVC中使用jackson包进行json转换,@RequestBody和@ResponseBody都是使用jackson进行json转换
<!--json转换-->
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-asl</artifactId>
<version>1.9.13</version>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>
4.配置json转换器,由于json的转换都是在controller方法调用的时候进行的,所以我们配置的json转换器需要加入到HandlerAdapter(处理器适配器)
<!-- 注解的 处理器适配器 -->
<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>
注意: 如果我们使用的是以下方式配置处理器映射器(HandlerAdapter),则我们不再需要配置json转换器
<!-- mvc注解驱动配置(一键代替(注解)处理器映射器和(注解)处理器适配器) -->
<mvc:annotation-driven></mvc:annotation-driven>
5.@RequestBody/@ResponseBody
@RequestBody:接收一个json格式数据串
@ResponseBody:返回一个json格式数据串
6.遇到的问题: 从数据库查询出来的数据若存在Date类型,在转换为Json时会变成Long类型
解决: 定义转换器(Jackson)
1.需要引入jackson-databind相关包
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>${jackson-databind}</version>
</dependency>
2.配置json转换器
<!-- mvc注解驱动配置(一键代替(注解)处理器映射器和(注解)处理器适配器) -->
<mvc:annotation-driven
conversion-service="conversionService" validator="validator">
<mvc:message-converters>
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<property name="objectMapper">
<bean class="com.fasterxml.jackson.databind.ObjectMapper">
<property name="dateFormat">
<bean class="java.text.SimpleDateFormat">
<constructor-arg type="java.lang.String" value="yyyy-MM-dd" />
</bean>
</property>
</bean>
</property>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
3.有需要的话定义数据格式
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday;
SpringMVC对于Restful的支持:
简写Rest(Representational State Transfer)
1.Restful是一种开发里面,是对http的一种诠释
http :
GET: 查询
POST: 添加
PUT: 修改
DELETE: 删除
2.非Restful风格url: http://localhost:8080/items/getItemsById?id=001
Restful风格url: http://localhost:8080/items/001
Restful特点:
1.url简洁,将参数通过url传递到服务端
2.不管是添加,删除,修改,url都是一致的,如果需要修改,则需要修改http method为POST,删除为DELETE,添加为PUT
3.例子:
//url中的{id}表示将id参数传递到@PathVariable("id")配置的指定名称中
@RequestMapping(value = "/getUserById/{id}/{type}")
public ModelAndView getUserById(@PathVariable("id") Integer Id,@PathVariable("type") String type) throws Exception {}
4.配置restful的前端控制器(主要是url-pattern只能使用/) ,另外需要注意的是,SpringMVC中可以配置多个前端控制器,他会根据不同风格的url使用不同的前端控制器进行映射
<servlet>
<servlet-name>springMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>ContextConfigLocation</param-name>
<param-value>classpath:resources/springMVC/SpringMVCBeans.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
5.其它用处,对于静态资源的解析
<!--静态资源解析 js/css/img... -->
<mvc:resources location="/js/" mapping="/js/**"/>