SpringBoot完美使⽤FastJson解析Json数据
因为⼯作中⽐较习惯使⽤的json框架是fastjson,所以spring boot默认的jackson使⽤起来⽐较不习惯,所以很⾃然我就想我能不能使⽤fastjson进⾏json解析呢?
引⼊fastjson依赖库
<!-- 添加fastjson 依赖包 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.15</version>
</dependency>
这⾥要提⽰⼀下,官⽅⽂档从的1.2.10以后,会有两个⽅法⽀持HttpMessageconvert,⼀个是FastJsonHttpMessageConverter,⽀持4.2以下的版本,⼀个是FastJsonHttpMessageConverter4⽀持4.2
以上的版本,具体有什么区别暂时没有深⼊研究。这⾥也就是说:低版本的就不⽀持了,所以这⾥最低要求就是1.2.10+。
配置fastjon(⽀持两种⽅法)
第⼀种⽅法就是:
(1)启动类继承extends WebMvcConfigurerAdapter
(2)覆盖⽅法configureMessageConverters
在我们原来的项⽬基础上,只要在App.class中添加代码就⾏:
@SpringBootApplication
public class ApiCoreApp extends WebMvcConfigurerAdapter {
/*
* 1、需要先定义⼀个 convert 转换消息的对象;
* 2、添加fastJson 的配置信息,⽐如:是否要格式化返回的json数据;
* 3、在convert中添加配置信息.
* 4、将convert添加到converters当中.
*
*/
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {fastjson怎么用
//1.需要先定义⼀个 convert 转换消息的对象;
FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter();
//2、添加fastJson 的配置信息,⽐如:是否要格式化返回的json数据;
FastJsonConfig fastJsonConfig = new FastJsonConfig();
fastJsonConfig.setSerializerFeatures(
SerializerFeature.PrettyFormat
);
//3、在convert中添加配置信息.
fastConverter.setFastJsonConfig(fastJsonConfig);
//4、将convert添加到converters当中.
converters.add(fastConverter);
}
}
第⼆种⽅法就是:
(1)在App.java启动类中,注⼊Bean : HttpMessageConverters第⼀种⽅法就是:
然后运⾏: 我们从控制台或是打印出来的json都看不出它到底使⽤了fastjson还是jackson来解析的,所我们在实体类在添加字段来区别它;
/**
* 在这⾥我们使⽤ @Bean 注⼊ fastJsonHttpMessageConvert
* @return
*/
@Bean
public HttpMessageConverters fastJsonHttpMessageConverters () {
// 1、需要先定义⼀个 convert 转换消息的对象;
FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter();
//2、添加fastJson 的配置信息,⽐如:是否要格式化返回的json 数据;
FastJsonConfig fastJsonConfig = new FastJsonConfig();
fastJsonConfig.setSerializerFeatures(SerializerFeature.PrettyFormat);
//3、在convert 中添加配置信息.
fastConverter.setFastJsonConfig(fastJsonConfig);
//4、将convert 添加到converters 当中.
HttpMessageConverter<?> converter = fastConverter;
return new HttpMessageConverters(converter); }
package zking.spring_boot_hello1;
import java.util.Date;
import com.alibaba.fastjson.annotation.JSONField;
/**
* 实体类
* @author Administrator
*
*/
public class Dome {
private Integer id;
private String name;
//这个注解是使⽤了com.alibaba.fastjson.annotation.JSONField
@JSONField(format="yyyy-MM-dd HH:mm")
private Date createTime;//时间
/**
* 在说⼀个注解就是
* serialize:是否需要序列化属性.
* 注解之后不返回的该属性的值,在项⽬中我们有些字段是不想返回,就可以⽤这个注解来实现 */
@JSONField(serialize=false)
private String remarks;//备注
public Dome(){
}
public Dome(Integer id, String name) {
super();
this.id = id;
this.name = name;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Date getCreateTime() {
return createTime;
}
public void setCreateTime(Date createTime) {
}
public String getRemarks() {
return remarks;
}
public void setRemarks(String remarks) {
}
}
然后到controller给这个对象去赋值:
package zking.spring_boot_hello1;
import java.util.Date;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* 在这⾥我们使⽤RestController (等价于 @Controller和 @RequestBody)
* @author Administrator
*
*/
@RestController
@RequestMapping("/demo")
public class HelloController {
@RequestMapping("/hello")
public String hello(){
return"hello";
}
/**
* 返回demo数据:
* 请求地址:127.0.0.1:8080/demo/getDemo
* @return
*/
@RequestMapping("/getDome")
public Dome getDome(){
Dome dome=new Dome();
dome.setId(1);
dome.setName("张三");
dome.setCreateTime(new Date());
dome.setRemarks("这是⼀个备注信息");
return dome;
}
}
去App.class运⾏,效果如图:
我们可以看到我们成功的使⽤fastjson解析好了,⽽且我们的备注信息也没有。这说明我们解析成功了。ps:觉得我写的东西对你有帮助就点⼀个赞,⽀持⼀下。你的⼀份⽀持就是我最⼤的动⼒。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论