接口层代码逻辑
- 返回值是一个Result对象,分为 code、data、errorMsg等。这样如果调用异常,可以告知调用方异常的类型,更友好
- 校验参数,并且根据参数的校验情况,返回不同的错误码(封装成枚举类)(千万不要再去做逻辑加工,否则就坑爹了)
ValidateUtilEntity checkResult= this.validateParam();
if( checkResult.isFail()){
return checkResult.getResult();
}
加工参数(check + fill)
ValidateUtilEntity checkHeaderResult= this.checkAndProcessHeader();执行业务逻辑,并且做好异常的处理
封装返回结果为 Result对象
Demo
工具类 ValidateUtilEntity.java
/**
* @program:
* @create: 2019-07-17 10:48
* 校验工具类
* 1. 如果校验成功,则校验函数返回ValidateUtilEntity.success(),状态码成功
* 2. 如果校验失败,则校验函数返回ValidateUtilEntity.fail(错误信息),状态码失败,且包含失败的Result
**/
public class ValidateUtilEntity {
private boolean isSuccess;
private static Result result = new Result();
public ValidateUtilEntity(boolean isSuccess) {
this.isSuccess = isSuccess;
}
public ValidateUtilEntity(boolean isSuccess, Result result) {
this.isSuccess = isSuccess;
this.result = result;
}
public static ValidateUtilEntity success() {
return new ValidateUtilEntity(true);
}
public static ValidateUtilEntity fail(ResponseCodeEnum responseCodeEnum) {
result = responseCodeEnum.bindFailureResult(result);
return new ValidateUtilEntity(false, result);
}
public static ValidateUtilEntity fail(ResponseCodeEnum responseCodeEnum, String extraErrorMsg) {
result = responseCodeEnum.bindFailureResult(result, extraErrorMsg);
return new ValidateUtilEntity(false, result);
}
/**
*方便调用,更直观
**/
public boolean isFail() {
return !isSuccess;
}
public boolean isSuccess() {
return isSuccess;
}
public void setSuccess(boolean success) {
isSuccess = success;
}
public Result getResult() {
return this.result;
}
}
使用示例
@PostMapping(value = "rest/json2json/{interfaceName}")
public Result restXml2Json(@RequestBody String body, @PathVariable("interfaceName") String interfaceName,
HttpServletRequest request) {
Result<Object> result = new Result<>();
InterfaceDetail interfaceDetail = interfaceDetailService.getInterfaceByName(interfaceName);
if (interfaceDetail == null) {
return ResponseCodeEnum.PARAM_ERROR.bindFailureResult(result);
}
HttpHeaders requestHeaders = new HttpHeaders();
ValidateUtilEntity checkHeaderResult = this.checkAndProcessHeaderInfo(requestHeaders, interfaceDetail, request);
if (checkHeaderResult.isFail()) {
return checkHeaderResult.getResult();
}
log.debug("{}请求:{}", interfaceName, body);
try {
String resultBody = this.invokeRestTemplate(body, requestHeaders, interfaceDetail);
log.debug("{}返回:{}", interfaceDetail.getName(), resultBody);
return result.successGlobalCode(JSONObject.parseObject(resultBody));
} catch (Exception e) {
log.error("调用接口异常:", e);
return ResponseCodeEnum.INVOKE_ERROR.bindFailureResult(result, e.getMessage());
}
}
private String invokeRestTemplate(String body, HttpHeaders requestHeaders, InterfaceDetail interfaceDetail) {
HttpEntity<String> requestEntity = new HttpEntity<>(body, requestHeaders);
ResponseEntity<String> responseEntity = restTemplate.exchange(interfaceDetail.getUrl(), HttpMethod.POST,
requestEntity, String.class);
return responseEntity.getBody();
}
private ValidateUtilEntity checkAndProcessHeaderInfo(HttpHeaders requestHeaders, InterfaceDetail interfaceDetail, HttpServletRequest request) {
requestHeaders.setContentType(MediaType.APPLICATION_JSON_UTF8);
// 设置头部
if (StringUtils.isNotBlank(interfaceDetail.getHeader())) {
String[] headerKey = interfaceDetail.getHeader().split(",");
for (String key : headerKey) {
String value = request.getHeader(key);
if (null == value) {
return ValidateUtilEntity.fail(ResponseCodeEnum.PARAMHEADER_ERROR, key);
}
requestHeaders.add(key, value);
}
}
return ValidateUtilEntity.success();
}
错误返回值的枚举类
public enum ResponseCodeEnum {
OK("0", "OK"),
PARAM_ERROR("EC002M01", "未找到接口相关配置"),
PARAMHEADER_ERROR("EC002M02", "缺少请求头信息:%s"),
PARSE_ERROR("EC002M03", "格式化参数异常"),
PARSERESULT_ERROR("EC002M04", "解析返回结果异常"),
INVOKE_ERROR("EC002M10", "调用接口异常:%s"),
OTHER_ERROR("EC002M99", "其他错误");
private String code;
private String msg;
private ResponseCodeEnum(String code, String msg) {
this.code = code;
this.msg = msg;
}
//根据枚举的code获取msg的方法
public static String getMsgByCode(String code){
for(ResponseCodeEnum responseEnum : ResponseCodeEnum.values()) {
if(responseEnum.getCode().equals(code)){
return responseEnum.msg;
}
}
return null;
}
public <T> Result<T> bindFailureResult(Result<T> result, Object... args) {
String msgResult = String.format(this.msg, args);
return result.failureGlobal(this.code, msgResult);
}
public String getCode() {
return code;
}
public String getMsg() {
return msg;
}
}