亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

API返回對象ResponseDTO<T>,包括以下部分

  • result:調(diào)用是否成功
  • code:狀態(tài)碼
  • msg:結(jié)果消息
  • data:響應(yīng)數(shù)據(jù),泛型<T>,可以接收任何數(shù)據(jù)類型

ResponseDTO源碼如下:

package com.study.web.dto;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class ResponseDTO<T> {
 /**
 * 調(diào)用是否成功
 */
 @Builder.Default
 private boolean result = true;
 /**
 * 狀態(tài)碼
 */
 @Builder.Default
 private String code = "200";
 /**
 * 結(jié)果消息
 */
 @Builder.Default
 private String msg = "";
 /**
 * 響應(yīng)數(shù)據(jù)
 */
 private T data;
 /** 
 * <p> 返回成功結(jié)果,無返回結(jié)果集 </p >
 * 
 * @return ResponseDTO<T>
 */
 public static <T> ResponseDTO<T> success() {
 return success(null);
 }
 /** 
 * <p> 返回成功結(jié)果,有返回結(jié)果集 </p >
 * 
 * @return ResponseDTO<T>
 */
 @SuppressWarnings("unchecked")
 public static <T> ResponseDTO<T> success(T data) {
 return ((ResponseDTO<T>) ResponseDTO.builder().result(true).code("200").msg("").data(data).build());
 }
 /** 
 * <p> 返回失敗結(jié)果,無返回結(jié)果集 </p >
 * 
 * @return ResponseDTO<T>
 */
 public static <T> ResponseDTO<T> error() {
 return error(null);
 }
 /** 
 * <p> 返回失敗結(jié)果,有返回結(jié)果集 </p >
 * 
 * @return ResponseDTO<T>
 */
 @SuppressWarnings("unchecked")
 public static <T> ResponseDTO<T> error(T data) {
 return ((ResponseDTO<T>) ResponseDTO.builder().result(false).data(data).build());
 }
}

示例代碼:

1、無返回Data

/**
 * 無返回Data
 */
 @PostMApping("/testVoid")
 public ResponseDTO<Void> testVoid(){
 ResponseDTO<Void> result = ResponseDTO.success();
 try {
 //業(yè)務(wù)代碼
 studyService.testVoid();
 } catch (Exception e) {
 log.error("處理異常", e);
 result.setResult(false);
 result.setCode("500");
 result.setMsg("異常");
 }
 return result;
 }

2、返回對象

/**
 * 返回對象
 */
 @PostMapping("/testString")
 public ResponseDTO<String> testString(){
 
 ResponseDTO<String> result = ResponseDTO.success();
 try {
 //業(yè)務(wù)代碼
 String data = studyService.testString();
 result.setData(data);
 } catch (Exception e) {
 log.error("處理異常", e);
 result.setResult(false);
 result.setCode("500");
 result.setMsg("異常");
 }
 return result;
 }

3、返回對象列表

/**
 * 返回對象列表
 */
 @PostMapping("/testList")
 public ResponseDTO<List<String>> testList(){
 ResponseDTO<List<String>> result = ResponseDTO.success();
 try {
 //業(yè)務(wù)代碼
 List<String> data = studyService.testList();
 result.setData(data);
 } catch (Exception e) {
 log.error("處理異常", e);
 result.setResult(false);
 result.setCode("500");
 result.setMsg("異常");
 }
 return result;
 }

在這里我以String型來代表任何類型的對象。

建議:controller層,接口級代碼,不要涉及過多業(yè)務(wù)代碼,業(yè)務(wù)代碼都放在service層處理并返回。

如何優(yōu)雅的處理API接口的返回?cái)?shù)據(jù)-----附源碼

 

controller層源碼:

package com.study.web.controller;
import JAVA.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.study.service.StudyService;
import com.study.web.dto.ResponseDTO;
import lombok.extern.slf4j.Slf4j;
@RestController
@Slf4j
@RequestMapping("/study")
public class StudyController {
 @Autowired
 StudyService studyService;
 /**
 * 無返回Data
 */
 @PostMapping("/testVoid")
 public ResponseDTO<Void> testVoid(){
 ResponseDTO<Void> result = ResponseDTO.success();
 try {
 //業(yè)務(wù)代碼
 studyService.testVoid();
 } catch (Exception e) {
 log.error("處理異常", e);
 result.setResult(false);
 result.setCode("500");
 result.setMsg("異常");
 }
 return result;
 }
 /**
 * 返回對象
 */
 @PostMapping("/testString")
 public ResponseDTO<String> testString(){
 ResponseDTO<String> result = ResponseDTO.success();
 try {
 //業(yè)務(wù)代碼
 String data = studyService.testString();
 result.setData(data);
 } catch (Exception e) {
 log.error("處理異常", e);
 result.setResult(false);
 result.setCode("500");
 result.setMsg("異常");
 }
 return result;
 }
 /**
 * 返回對象列表
 */
 @PostMapping("/testList")
 public ResponseDTO<List<String>> testList(){
 ResponseDTO<List<String>> result = ResponseDTO.success();
 try {
 //業(yè)務(wù)代碼
 List<String> data = studyService.testList();
 result.setData(data);
 } catch (Exception e) {
 log.error("處理異常", e);
 result.setResult(false);
 result.setCode("500");
 result.setMsg("異常");
 }
 return result;
 }
}

service層源碼:

package com.study.service;
import java.util.List;
import org.springframework.stereotype.Service;
@Service
public class StudyService {
 public void testVoid(){
 }
 public String testString(){
 return null;
 }
 public List<String> testList(){
 return null;
 }
}

分享到:
標(biāo)簽:接口 API
用戶無頭像

網(wǎng)友整理

注冊時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定