因为工作中比较习惯使用的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) {
super.configureMessageConverters(converters);
//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第一种方法就是:
/**
* 在这里我们使用 @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);
}
然后运行:
我们从控制台或是打印出来的json都看不出它到底使用了fastjson还是jackson来解析的,所我们在实体类在添加字段来区别它;
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) {
this.createTime = createTime;
}
public String getRemarks() {
return remarks;
}
public void setRemarks(String remarks) {
this.remarks = 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数据:
* 请求地址:http://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:觉得我写的东西对你有帮助就点一个赞,支持一下。你的一份支持就是我最大的动力。