我们在使用Spring MVC 是都有这样的经历,@ResponseBody返回一个JSON格式字符串到前端,或者使用@RequestBody获取前端REST提交的对象,那么Spring MVC 中是如何处理的呢?大体的流程如下:
在Spring Web中使用 jackson处理,具体实现类是MappingJackson2HttpMessageConverter. 具体的JSON系列化和反序列化都是有jackson实现的。下面主要介绍一下jackson的使用。
对日期进行JSON序列化:
/** * * @author zhangwei<wei.zw@corp.netease.com> * @since 2015年9月18日 下午4:08:08 * @version v 0.1 */ public class ContainDateObject { private Date startTime; private Date endTime; public Date getStartTime() { return startTime; } public void setStartTime(Date startTime) { this.startTime = startTime; } public Date getEndTime() { return endTime; } public void setEndTime(Date endTime) { this.endTime = endTime; } }
@Test public void testDate() throws JsonProcessingException { ContainDateObject cdo = new ContainDateObject(); cdo.setStartTime(new Date()); cdo.setEndTime(new Date()); System.out.println(objectMapper.writeValueAsString(cdo)); }
结果是:
{"startTime":1442563815734,"endTime":1442563815734}
这样的结果有的时候是无法接受的,我们有的时候需要一个yyyy-MM-dd HH:mm:ss这样格式的字符串改如何处理呢?这个时候我们就需要制定一个自定义的序列化类;
/** * Desc:自定义日期类型序列化类 * * @author zhangwei<wei.zw@corp.netease.com> * @since 2015年9月18日 下午4:12:51 * @version v 0.1 */ public class DateJsonSerializer extends JsonSerializer<Date> { /** * @see com.fasterxml.jackson.databind.JsonSerializer#serialize(java.lang.Object, * com.fasterxml.jackson.core.JsonGenerator, * com.fasterxml.jackson.databind.SerializerProvider) */ @Override public void serialize(Date date, JsonGenerator generator, SerializerProvider provider) throws IOException, JsonProcessingException { ObjectMapper om = new ObjectMapper(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); om.writeValue(generator, sdf.format(date)); } }
在需要按照指定格式进行序列化的日期属性上添加注解
@JsonSerialize(using = DateJsonSerializer.class) private Date startTime; @JsonSerialize(using = DateJsonSerializer.class) private Date endTime;
测试的结果是:
{"startTime":"2015-09-18 16:23:23","endTime":"2015-09-18 16:23:23"}
这样的结果就比较符合预期了
反过来,使用这个JSON转换为一个对象时的结果怎样呢?
@Test public void testDate() throws Exception { ContainDateObject cdo = new ContainDateObject(); cdo.setStartTime(new Date()); cdo.setEndTime(new Date()); String serializerResult = objectMapper.writeValueAsString(cdo); cdo = objectMapper.readValue(serializerResult, ContainDateObject.class); }
结果却是:
com.fasterxml.jackson.databind.exc.InvalidFormatException: Can not construct instance of java.util.Date from String value '2015-09-18 16:26:58': not a valid representation (error: Failed to parse Date value '2015-09-18 16:26:58': Can not parse date "2015-09-18 16:26:58": not compatible with any of standard forms ("yyyy-MM-dd'T'HH:mm:ss.SSSZ", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", "EEE, dd MMM yyyy HH:mm:ss zzz", "yyyy-MM-dd")) at [Source: {"startTime":"2015-09-18 16:26:58","endTime":"2015-09-18 16:26:58"}; line: 1, column: 2] (through reference chain: com.david.demo.jackson.ContainDateObject["startTime"]) at com.fasterxml.jackson.databind.exc.InvalidFormatException.from(InvalidFormatException.java:55) at com.fasterxml.jackson.databind.DeserializationContext.weirdStringException(DeserializationContext.java:883) at com.fasterxml.jackson.databind.deser.std.StdDeserializer._parseDate(StdDeserializer.java:750) at com.fasterxml.jackson.databind.deser.std.DateDeserializers$DateBasedDeserializer._parseDate(DateDeserializers.java:176) at com.fasterxml.jackson.databind.deser.std.DateDeserializers$DateDeserializer.deserialize(DateDeserializers.java:262) at com.fasterxml.jackson.databind.deser.std.DateDeserializers$DateDeserializer.deserialize(DateDeserializers.java:246) at com.fasterxml.jackson.databind.deser.SettableBeanProperty.deserialize(SettableBeanProperty.java:523) at com.fasterxml.jackson.databind.deser.impl.MethodProperty.deserializeAndSet(MethodProperty.java:95) at com.fasterxml.jackson.databind.deser.impl.BeanPropertyMap.findDeserializeAndSet(BeanPropertyMap.java:285) at com.fasterxml.jackson.databind.deser.BeanDeserializer.vanillaDeserialize(BeanDeserializer.java:248) at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:136) at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:3562) at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:2578)
反序列化失败了,这又改如何处理呢?我们同样指定反序列化类
/** * Desc:日期类型的反序列化类 * * @author zhangwei<wei.zw@corp.netease.com> * @since 2015年9月18日 下午4:31:02 * @version v 0.1 */ public class DateJsonDeserializer extends JsonDeserializer<Date> { /** * @see com.fasterxml.jackson.databind.JsonDeserializer#deserialize(com.fasterxml.jackson.core.JsonParser, * com.fasterxml.jackson.databind.DeserializationContext) */ @Override public Date deserialize(JsonParser parser, DeserializationContext context) throws IOException, JsonProcessingException { try { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); return sdf.parse(parser.getValueAsString()); } catch (Exception e) { e.printStackTrace(); } return null; } }
@JsonSerialize(using = DateJsonSerializer.class) @JsonDeserialize(using = DateJsonDeserializer.class) private Date startTime; @JsonSerialize(using = DateJsonSerializer.class) @JsonDeserialize(using = DateJsonDeserializer.class) private Date endTime;
这样反序列化问题也可以很好地解决了。
我们再想对象中添加一个个人隐私信息字段 phone;
@JsonSerialize(using = DateJsonSerializer.class) @JsonDeserialize(using = DateJsonDeserializer.class) private Date startTime; @JsonSerialize(using = DateJsonSerializer.class) @JsonDeserialize(using = DateJsonDeserializer.class) private Date endTime; private String phone;
@Test public void testDate() throws Exception { ContainDateObject cdo = new ContainDateObject(); cdo.setStartTime(new Date()); cdo.setEndTime(new Date()); cdo.setPhone("13919309243"); String serializerResult = objectMapper.writeValueAsString(cdo); System.out.println(serializerResult); objectMapper.readValue(serializerResult, ContainDateObject.class); }
这样序列化的结果是:
{"startTime":"2015-09-18 16:37:34","endTime":"2015-09-18 16:37:34","phone":"13919309243"}
phone是一个个人隐私信息,如果不想被序列化改如何处理?只需要在该属性上添加一个注解
@JsonIgnore private String phone;
再次序列化的结果是:
{"startTime":"2015-09-18 16:43:15","endTime":"2015-09-18 16:43:15"}
相关推荐
class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter" /> class="org.springframework.http.converter.StringHttpMessageConverter"> <value>text/html;charset=utf-8 ...
与之配套的是Jackson库,这是一款高效的JSON处理库,常用于Spring MVC应用中进行数据序列化和反序列化。 在使用Spring Framework 4.3.8时,确保你的Java Development Kit (JDK)版本至少是1.8。这是由于Spring框架4....
在Java开发领域,Spring框架是应用最广泛的框架之一,它为构建高质量的Web应用程序提供了强大的支持。而Jackson库则是处理JSON数据的利器,它能够帮助我们轻松地将Java对象序列化为JSON格式,以及将JSON反序列化为...
在IT行业中,Jackson库是Java领域广泛使用的JSON处理库,特别是在Spring框架中。"jackson-annotations"、"jackson-core"和"jackson-databind"是Jackson库的三个核心模块,它们协同工作,提供了强大的JSON序列化和反...
Spring会使用合适的HttpMessageConverter(如Jackson的`MappingJackson2HttpMessageConverter`)来完成转换。 - **@ResponseBody**:用于标记方法返回值,表明返回的内容应直接写入HTTP响应体,而不是视图解析。...
这可以通过在`WebApplicationContext`中添加`MappingJackson2HttpMessageConverter` bean来完成,或者在XML配置中指定`<mvc:annotation-driven>`,这样Spring会自动添加所需的MessageConverters。 6. 示例代码: `...
- `MappingJackson2HttpMessageConverter`:用于 JSON 数据转换,基于 Jackson 库。 - `XmlAwareFormHttpMessageConverter`:处理 HTML 表单数据。 - `ResourceHttpMessageConverter`:处理 `java.io.InputStream...
2. **Spring MVC集成**:在Spring MVC中,通过在配置类中添加`Jackson2ObjectMapperBuilder`和`MappingJackson2HttpMessageConverter`,可以将Jackson自动装配到Spring MVC的处理链中。这使得Spring MVC能够将Java...
本篇文章将深入探讨这个问题,提供解决方案,并涉及Spring MVC、Jackson等相关技术。 首先,理解`@ResponseBody`的作用至关重要。它是Spring MVC中的一个注解,用于指示控制器方法的返回值应直接写入HTTP响应体,而...
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/> ``` 在使用Jackson处理Dubbo服务时,同样需要确保Dubbo服务提供者和消费者两边的Jackson版本一致,以避免...
如果项目中已经引入了这两个jar文件,但仍然收到406错误,可能是因为Spring MVC没有正确地识别并使用Jackson作为默认的HttpMessageConverter。解决这个问题的方法有以下几点: 1. **配置Spring MVC**:在Spring的...
2. 配置Spring MVC,使它能够使用Jackson进行JSON转换,通常在`web.xml`中配置`MappingJackson2HttpMessageConverter`。 **防御XSS攻击** XSS(Cross-Site Scripting)是一种常见的Web应用安全漏洞,允许攻击者...
在Spring MVC中,通常会配置`MappingJackson2HttpMessageConverter`或`Jackson2ObjectMapperBuilder`来自动处理JSON的序列化和反序列化。这样,当你在控制器中返回一个对象时,Spring会自动调用Jackson将其转换为...
虽然`MappingJackson2HttpMessageConverter`基于Jackson库,但Spring也支持其他序列化库,如Gson、Fastjson等。通过配置,可以替换默认的消息转换器以使用这些库。 6. **异常处理** 当JSON反序列化失败时,`...
在Spring MVC中,这可能是因为配置的MessageConverter不支持请求或响应的数据格式,或者Jackson库的版本太低,不支持Spring 4.1所需的JSON处理功能。 要解决这个问题,你需要确保以下几点: 1. **版本匹配**:确保...
在Spring MVC中,通过配置`MappingJackson2HttpMessageConverter`或`Jackson2ObjectMapperBuilder`,可以让Spring自动使用Jackson进行HTTP请求和响应之间的JSON转换。这使得开发人员能够轻松地在控制器方法中接收和...
`MappingJackson2HttpMessageConverter`是Spring MVC中默认的JSON消息转换器,它依赖于Jackson的核心库来处理HTTP请求和响应的JSON数据。通过自定义`MessageConverter`或者调整Spring的配置,我们可以定制Jackson的...
总的来说,`jackson-all-1.9.11.jar`是Spring MVC 3.0实现高效JSON数据交换的关键依赖之一,它提供了高效的JSON处理能力,使得开发者能够专注于业务逻辑,而无需关心底层的数据转换细节。随着技术的发展,虽然现在更...
通过配置Spring的`MappingJackson2HttpMessageConverter`,可以自动将Controller方法的返回值转化为JSON格式,并发送到客户端。 除了基本的功能外,Jackson库还有许多高级特性,如类型转换、类型安全的泛型处理、...
在Spring的配置文件中,通常需要配置一个`MessageConverter`,比如`MappingJackson2HttpMessageConverter`,来告诉Spring使用Jackson处理JSON。在Spring Boot项目中,这通常是自动配置的,而在传统的Spring MVC项目...