设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

一个项目的SpringCloud微服务改造过程(9)

发布时间:2019-08-06 16:22 所属栏目:21 来源:黄玲峰
导读:一般编码时有异常我们都会try-catch捕获异常,有时为了区分不同的异常还会一次catch多个异常,大量的try-catch语句,这样使得代码也不够优雅;一个相同的异常处理写多次代码也比较冗余,所以引入全局的异常处理非常

一般编码时有异常我们都会try-catch捕获异常,有时为了区分不同的异常还会一次catch多个异常,大量的try-catch语句,这样使得代码也不够优雅;一个相同的异常处理写多次代码也比较冗余,所以引入全局的异常处理非常必要。
改造前的异常处理配置文件:

  1. <!--定义异常处理页面--> 
  2. <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> 
  3.         <property name="exceptionMappings"> 
  4.             <props> 
  5.                 <prop key="com.creditease.permissionapi.exception.NopermissionException">/permission/noSecurity</prop> 
  6.             </props> 
  7.         </property> 
  8.  </bean> 

使用SimpleMappingExceptionResolver类处理异常,设置自定义异常类型NopermissionException,以及异常发生后的请求路径/permission/noSecurity。

SpringBoot中采用@RestControllerAdvice或者@ControllerAdvice设置全局异常类。这两者区别类似于@Controller和@RestController注解。
SSO中定义了三种全局的异常处理:普通的Exception处理;自定的NopermissionException异常和参数校验异常。

全局异常处理代码如下:

  1. @Configuration 
  2. @Slf4j 
  3. @RestControllerAdvice 
  4. public class GlobalExceptionConfig { 
  5. //无权限处理 
  6. @ExceptionHandler(value = {NopermissionException.class}) 
  7. public void noPermissionExceptionHandler(HttpServletRequest request, Exception ex, HttpServletResponse response, @Value("${sso.server.prefix}") String domain) throws IOException { 
  8. printLog(request,ex); 
  9. response.sendRedirect("跳转到无权限页面地址"); 
  10.  
  11. //参数校验处理 
  12. @ExceptionHandler(value = {BindException.class}) 
  13. public ResultBody BindExceptionHandler(BindException bindException){ 
  14. List<ObjectError> errors = bindException.getBindingResult().getAllErrors(); 
  15. //这个ResultBody是一个返回结果对象,这里需要返回json,里面包含了状态码和提示信息 
  16. return ResultBody.buildFailureResult(errors.get(0).getDefaultMessage()); 
  17.  
  18. //所有未捕获的异常处理逻辑 
  19. @ExceptionHandler(value = {Exception.class}) 
  20. public ResultBody exceptionHandler(HttpServletRequest request,Exception ex){ 
  21. printLog(request,ex); 
  22. return ResultBody.buildExceptionResult(); 
  23.  
  24. //将请求参数和异常打印出来,结合@slf4j注解 
  25. public void printLog(HttpServletRequest request,Exception ex){ 
  26. String parameters = JsonHelper.toString(request.getParameterMap()); 
  27. log.error("url>>>:{},params>>>:{} ,printLog>>>:{}",request.getRequestURL(),parameters,ex); 
  28.  

@RestControllerAdvice结合@Validation,可以对Bean进行校验,校验不通过会抛出BindException异常。通过注解可以少写if-else代码,判断请求的接口参数是否为空,提高代码的美观性。例如:

  1.  //常规做法 
  2.     if(StringUtils.isEmpty(ssoSystem.getSysCode()) 
  3. //SSO做法 
  4. //在Controller请求方法上添加@Valid注解 
  5. @RequestMapping(value = "/add", method = RequestMethod.POST) 
  6. public ResultBody add(@Valid @RequestBody SsoSystem ssoSystem) { 
  7.  
  8.  
  9. //在需要处理的SsoSystem Bean的属性上加@NotNull注解 
  10. @NotNull(message = "系统编号不能为空") 
  11. private String sysCode;

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读