Springboot設(shè)置統(tǒng)一的返回格式的方法步驟
在我們應用中我們通常與前端交互使用json 格式,設(shè)置統(tǒng)一的返回json 格式是非常必要的,可以減少開發(fā)人員的工作量。
第一個使用統(tǒng)一的消息轉(zhuǎn)換器,這里使用jackson 的相關(guān)功能,引入jar
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
</dependency>創(chuàng)建一個全局配置類(GlobalConfig)并使用
@Configuration注解標記該類為配置類。然后,在該類上使用@EnableWebMvc注解開啟對MVC的支持。- 在該配置類中重寫
configureMessageConverters()方法,將Jackson消息轉(zhuǎn)換器添加到默認的消息轉(zhuǎn)換器列表中。示例如下所示:
@Configuration
@EnableWebMvc
public class GlobalConfig extends WebMvcConfigurerAdapter {
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
ObjectMapper objectMapper = new ObjectMapper();
// 設(shè)置日期序列化/反序列化格式
JavaTimeModule javaTimeModule = new JavaTimeModule();
javaTimeModule.addSerializer(LocalDateTime.class, LocalDateTimeSerializer.INSTANCE);
javaTimeModule.addDeserializer(LocalDateTime.class, LocalDateTimeDeserializer.INSTANCE);
objectMapper.registerModule(javaTimeModule);
// 其他自定義配置...
Jackson2ObjectMapperBuilder builder = new Jackson2ObjectMapperBuilder()
.serializationInclusion(JsonInclude.Include.NON_NULL)
.featuresToDisable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter(builder.build());
converters.add(converter);
}
}二、聲明統(tǒng)一格式的返回類型,一般包含code、message、data 三部分
1)定義一個返回結(jié)果 IResultStatus
public interface IResultStatus {
/**
* 業(yè)務狀態(tài)碼
* @return Integer
*/
Integer code();
/**
* 業(yè)務信息描述
* @return String
*/
String message();
}
2)創(chuàng)建一個枚舉實體
public enum ResultStatus implements IResultStatus {
/**
* 成功
*/
SUCCESS(200, "OK"),
/**
* 錯誤的請求,參數(shù)異常
*/
BAD_REQUEST(400, "Bad Request params exception"),
/**
* 服務器異常
*/
INTERNAL_SERVER_ERROR(500, "Internal Server Error"),
/**
* 401 未認證異常
*/
UNAUTHORIZED(401, "認證異常"),
/**
* 業(yè)務異常
*/
BUSINESS_ERR(10000, "業(yè)務異常");
/**
* 業(yè)務狀態(tài)碼
*/
private Integer code;
/**
* 業(yè)務信息描述
*/
private String message;
ResultStatus (Integer code, String message) {
this.code = code;
this.message = message;
}
/**
* 業(yè)務狀態(tài)碼
*
* @return Integer
*/
@Override
public Integer code() {
return code;
}
/**
* 業(yè)務信息描述
*
* @return String
*/
@Override
public String message() {
return message;
}
}3)引入lamada 定義返回實體
@Data
public class Result<T> {
/**
* 業(yè)務錯誤碼
*/
private Integer code;
/**
* 信息描述
*/
private String message;
/**
* 返回參數(shù)
*/
private T data;
private Result(IResultStatus resultStatus, T data) {
this.code = resultStatus.code();
this.message = resultStatus.message();
this.data = data;
}
private Result(Integer code, String message, T data) {
this.code = code;
this.message = message;
this.data = data;
}
/**
* 業(yè)務成功返回業(yè)務代碼和描述信息
*/
public static Result<Void> success() {
return new Result<Void>(ResultStatus.SUCCESS, null);
}
/**
* 業(yè)務成功返回業(yè)務代碼,描述和返回的參數(shù)
*/
public static <T> Result<T> success(T data) {
return new Result<T>(ResultStatus.SUCCESS, data);
}
/**
* 業(yè)務成功返回業(yè)務代碼,描述和返回的參數(shù)
*/
public static <T> Result<T> success(IResultStatus resultStatus, T data) {
if (resultStatus == null) {
return success(data);
}
return new Result<T>(resultStatus, data);
}
/**
* 業(yè)務成功返回業(yè)務代碼,描述和返回的參數(shù)
*/
public static <T> Result<T> success(Integer code, String message, T data) {
return new Result<T>(code, message, data);
}
/**
* 業(yè)務異常返回業(yè)務代碼和描述信息
*/
public static <T> Result<T> fail() {
return new Result<T>(ResultStatus.BUSINESS_ERR, null);
}
/**
* 業(yè)務異常返回業(yè)務代碼和描述信息
*/
public static <T> Result<T> fail(String message) {
return new Result<T>(ResultStatus.BUSINESS_ERR.code(), message, null);
}
/**
* 業(yè)務異常返回業(yè)務代碼,描述和返回的參數(shù)
*/
public static <T> Result<T> fail(IResultStatus resultStatus) {
return fail(resultStatus, null);
}
/**
* 業(yè)務異常返回業(yè)務代碼,描述和返回的參數(shù)
*/
public static <T> Result<T> fail(IResultStatus resultStatus, String message) {
if (resultStatus == null) {
return new Result<T>(ResultStatus.BUSINESS_ERR, null);
}
return new Result<T>(resultStatus.code(), message, null);
}
}上述實體我們都定義好了,可以結(jié)合我們的上述jackson 包進行配置json 配置
@Configuration
public class JsonSerializeConfig {
@Bean
@Primary
@ConditionalOnMissingBean(ObjectMapper.class)
public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
ObjectMapper objectMapper = builder.createXmlMapper(false).build();
.....這里省去自定義格式類型
}
}那么在使用時通過創(chuàng)建我們的返回實體進行接口返回。
public Result<> call((){
.......省去業(yè)務
return new Result();//根據(jù)構(gòu)造函數(shù)返回
}到此這篇關(guān)于Springboot設(shè)置統(tǒng)一的返回格式的方法步驟的文章就介紹到這了,更多相關(guān)Springboot設(shè)置統(tǒng)一返回格式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何設(shè)置IDEA遠程連接服務器開發(fā)環(huán)境并結(jié)合cpolar實現(xiàn)ssh遠程開發(fā)(最新推薦)
本文主要介紹如何在IDEA中設(shè)置遠程連接服務器開發(fā)環(huán)境,并結(jié)合Cpolar內(nèi)網(wǎng)穿透工具實現(xiàn)無公網(wǎng)遠程連接,然后實現(xiàn)遠程Linux環(huán)境進行開發(fā),感興趣的朋友跟隨小編一起看看吧2024-03-03
@MapperScan和@ComponentScan一塊使用導致沖突的解決
這篇文章主要介紹了@MapperScan和@ComponentScan一塊使用導致沖突的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
Java之Springcloud Gateway內(nèi)置路由案例講解
這篇文章主要介紹了Java之Springcloud Gateway內(nèi)置路由案例講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08
Java Web開發(fā)中過濾器和監(jiān)聽器使用詳解
這篇文章主要為大家詳細介紹了Java中的過濾器Filter和監(jiān)聽器Listener的使用以及二者的區(qū)別,文中的示例代碼講解詳細,需要的可以參考一下2022-10-10

