SpringBoot中Controller參數(shù)與返回值的用法總結(jié)
SpringBoot中Controller參數(shù)與返回值的用法
注解
類(lèi)注解一律使用@RestController,方法注解是實(shí)際情況而定。
返回值
SpringBoot在實(shí)際后端開(kāi)發(fā)中一般要為前端提供的數(shù)據(jù)是以json格式返回,其返回值類(lèi)型我們大多采用以下方式
public Map<String, Object> function() { ? ? Map<String, Object> modelMap = new HashMap<>(); ? ? //...我們將從數(shù)據(jù)中中獲取的值放入value ? ? modelMap.put("key", value); ? ? return modelMap; }
接收參數(shù)
普通參數(shù)
普通參數(shù)可以使用RESTful風(fēng)格返回值,路由中注明{param},注意@PathVariable注解的使用
? ? @RequestMapping("/route/{param}") ? ? public Map<String, Object> queryAreaById(@PathVariable("param") Integer param) { ? ? ? ? Map<String, Object> modelMap = new HashMap<>(); ? ? ? ? //...do something with param, save data in value ? ? ? ? modelMap.put("key", value); ? ? ? ? return modelMap; ? ? }
接收前端對(duì)象類(lèi)型參數(shù)(json格式),對(duì)參數(shù)使用@RequestBody注解
? ? @RequestMapping(value = "/route", method = RequestMethod.POST) ? ? public Map<String, Object> updateArea(@RequestBody XObject xObject) { ? ? ? ? Map<String, Object> modelMap = new HashMap<>(); ? ? ? ? //...do something with xObject, save data in value ? ? ? ? modelMap.put("key", value); ? ? ? ? return modelMap; ? ? }
springboot controller統(tǒng)一的接口返回值和異常處理
返回結(jié)果模型
@ApiModel("返回結(jié)果模型") public class JsonResult<T> implements Serializable { ?? ?@ApiModelProperty("返回結(jié)果提示") ?? ?private String msg = null; ?? ?@ApiModelProperty("返回結(jié)果狀態(tài)") ?? ?private String status = null; ?? ?@ApiModelProperty("返回結(jié)果數(shù)據(jù)") ?? ?private T result = null; ?? ?public String getStatus() { ?? ??? ?return status; ?? ?} ?? ?public void setStatus(String status) { ?? ??? ?this.status = status; ?? ?} ?? ?public T getResult() { ?? ??? ?return result; ?? ?} ?? ?public void setResult(T result) { ?? ??? ?this.result = result; ?? ?} ?? ?public String getMsg() { ?? ??? ?return msg; ?? ?} ?? ?public void setMsg(String msg) { ?? ??? ?this.msg = msg; ?? ?} ?? ?public JsonResult(){ ?? ?} ?? ?public JsonResult(String status, String msg, T result){ ?? ? ? ?this.status = status; ?? ? ? ?this.msg = msg; ?? ? ? ?this.result = result; ? ? } ? ? public JsonResult(String status, String msg){ ? ? ? ? this.status = status; ? ? ? ? this.msg = msg; ? ? } ? ? public JsonResult(ResultEnum resultEnum){ ?? ??? ?this.status = resultEnum.getStatus(); ?? ??? ?this.msg = resultEnum.getMsg(); ?? ?} ?? ?public JsonResult(ResultEnum resultEnum, T result){ ?? ??? ?this.status = resultEnum.getStatus(); ?? ??? ?this.msg = resultEnum.getMsg(); ?? ??? ?this.result = result; ?? ?} }
返回編碼枚舉類(lèi)模型
/** ?* @author code ?* @version 1.0 ?* @Date 2021/8/9 13:55 ?* @Description ${DESCRIPTION} ?*/ public enum ResultEnum { ? ? SUCCESS("ok","調(diào)用成功"), ? ? ERROR("error","調(diào)用失敗"); ? ? private String status; ? ? private String msg; ? ? public String getStatus() { ? ? ? ? return status; ? ? } ? ? public void setStatus(String status) { ? ? ? ? this.status = status; ? ? } ? ? public String getMsg() { ? ? ? ? return msg; ? ? } ? ? public void setMsg(String msg) { ? ? ? ? this.msg = msg; ? ? } ? ? ResultEnum(String status,String msg){ ? ? ? ? this.status = status; ? ? ? ? this.msg = msg; ? ? } }
返回結(jié)果工具類(lèi)
/** ?* @author code ?* @version 1.0 ?* @Date 2021/7/22 15:50 ?* @Description ${DESCRIPTION} ?*/ @Data @AllArgsConstructor @NoArgsConstructor @ApiModel("數(shù)據(jù)返回結(jié)果") public class ResultUtil<T> { ? ? public static JsonResult success(){ ? ? ? ? return new JsonResult(ResultEnum.SUCCESS); ? ? } ? ? public static JsonResult success(String msg){ ? ? ? ? return new JsonResult(ResultEnum.SUCCESS.getStatus(),msg); ? ? } ? ? public static <T> JsonResult<T> success(T result){ ? ? ? ? return new JsonResult<T>(ResultEnum.SUCCESS, result); ? ? } ? ? public static JsonResult error(){ ? ? ? ? return new JsonResult(ResultEnum.ERROR); ? ? } ? ? public static JsonResult error(String msg){ ? ? ? ? return new JsonResult(ResultEnum.ERROR.getStatus(),msg); ? ? } ? ? public static <T> JsonResult error(T result){ ? ? ? ? return new JsonResult<T>(ResultEnum.ERROR, result); ? ? } }
controller統(tǒng)一處理返回值
/** ?* @author code ?* @version 1.0 ?* @Date 2021/8/9 15:30 ?* @Description ${統(tǒng)一返回值} ?*/ @RestControllerAdvice public class ControllerHandleAdvice implements ResponseBodyAdvice<Object> { ? ? private final static Logger logger = LoggerFactory.getLogger(ControllerHandleAdvice.class); ? ? @Override ? ? public boolean supports(MethodParameter methodParameter, Class<?extends HttpMessageConverter<?>> converterType){ ? ? ? ? return true; ? ? } ? ? @Override ? ? public Object beforeBodyWrite(Object body, MethodParameter methodParameter, MediaType mediaType, Class<?extends HttpMessageConverter<?>> converterType, ServerHttpRequest request, ServerHttpResponse response){ ? ? ? ? if(body instanceof String){ ? ? ? ? ? ? String msg = (String) body; ? ? ? ? ? ? return ResultUtil.success(msg); ? ? ? ? } else if(null == body) { ? ? ? ? } ? ? ? ? return body; ? ? } }
controller統(tǒng)一異常處理
/** ?* @author code ?* @version 1.0 ?* @Date 2021/8/9 10:56 ?* @Description ${統(tǒng)一異常返回值} ?*/ @RestControllerAdvice public class ControllerExceptionHandleAdvice { ? ? private final static Logger logger = LoggerFactory.getLogger(ControllerExceptionHandleAdvice.class); ? ? @ExceptionHandler ? ? public JsonResult handler(HttpServletRequest request, HttpServletResponse response,Exception e){ ? ? ? ? logger.info("restful請(qǐng)求異常"); ? ? ? ? JsonResult jsonResult = new JsonResult(); ? ? ? ? if(e instanceof NullPointerException){ ? ? ? ? ? ? logger.error("空指針異常"); ? ? ? ? ? ? jsonResult.setStatus("error"); ? ? ? ? ? ? jsonResult.setResult("空指針異常"); ? ? ? ? }else if(e instanceof IllegalArgumentException){ ? ? ? ? ? ? logger.error("請(qǐng)求參數(shù)類(lèi)型不匹配"); ? ? ? ? ? ? jsonResult.setStatus("error"); ? ? ? ? ? ? jsonResult.setResult("請(qǐng)求參數(shù)類(lèi)型不匹配"); ? ? ? ? }else if(e instanceof SQLException){ ? ? ? ? ? ? logger.error("數(shù)據(jù)庫(kù)訪問(wèn)異常"); ? ? ? ? ? ? jsonResult.setStatus("error"); ? ? ? ? ? ? jsonResult.setResult("數(shù)據(jù)庫(kù)訪問(wèn)異常"); ? ? ? ? }else { ? ? ? ? ? ? logger.error("訪問(wèn)異常"+e.getMessage()); ? ? ? ? ? ? jsonResult.setStatus("error"); ? ? ? ? ? ? jsonResult.setResult("服務(wù)訪問(wèn)異常"+e.getMessage()); ? ? ? ? } ? ? ? ? return jsonResult; ? ? } }
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Security使用多種加密方式進(jìn)行密碼校驗(yàn)的代碼示例
在Web應(yīng)用中,密碼的安全存儲(chǔ)和驗(yàn)證是至關(guān)重要的,本文將通過(guò)一個(gè)具體的代碼示例,介紹和總結(jié)如何在Spring Security中使用多種加密方式進(jìn)行密碼校驗(yàn),文中通過(guò)代碼講解得非常詳細(xì),需要的朋友可以參考下2024-06-06帶大家認(rèn)識(shí)Java語(yǔ)法之泛型與通配符
使用泛型的目的是利用Java編譯機(jī)制,在編譯過(guò)程中幫我們檢測(cè)代碼中不規(guī)范的有可能導(dǎo)致程序錯(cuò)誤的代碼,下面這篇文章主要給大家介紹了關(guān)于Java泛型與通配符的相關(guān)資料,需要的朋友可以參考下2022-03-03springboot如何使用@ConfigurationProperties封裝配置文件
springboot如何使用@ConfigurationProperties封裝配置文件的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08spring boot 加載web容器tomcat流程源碼分析
本文章主要描述spring boot加載web容器 tomcat的部分,為了避免文章知識(shí)點(diǎn)過(guò)于分散,其他相關(guān)的如bean的加載,tomcat內(nèi)部流程等不做深入討論,具體內(nèi)容詳情跟隨小編一起看看吧2021-06-06RestTemplate如何添加請(qǐng)求頭headers和請(qǐng)求體body
這篇文章主要介紹了RestTemplate如何添加請(qǐng)求頭headers和請(qǐng)求體body問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07SpringCloud分布式事務(wù)Seata部署和集成過(guò)程
這篇文章主要介紹了SpringCloud分布式事務(wù)Seata部署和集成過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-10-10Java中byte輸出write到文件的實(shí)現(xiàn)方法講解
今天小編就為大家分享一篇關(guān)于Java中byte輸出write到文件的實(shí)現(xiàn)方法講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03Java字符串?dāng)?shù)字左右補(bǔ)全0的四種方式
這篇文章主要給大家介紹了關(guān)于Java字符串?dāng)?shù)字左右補(bǔ)全0的四種方式,在編程中有時(shí)候我們需要對(duì)一個(gè)字符串進(jìn)行字符填充,以滿(mǎn)足某些特定的要求,其中補(bǔ)全0是一種常見(jiàn)的需求,需要的朋友可以參考下2023-08-08詳解Java面向?qū)ο笾鄳B(tài)的原理與實(shí)現(xiàn)
多態(tài)是指不同的子類(lèi)在繼承父類(lèi)后分別都重寫(xiě)覆蓋了父類(lèi)的方法,即父類(lèi)同一個(gè)方法,在繼承的子類(lèi)中表現(xiàn)出不同的形式。本文將詳解多態(tài)的原理與實(shí)現(xiàn),感興趣的可以學(xué)習(xí)一下2022-05-05