【Java】统一异常处理

场景如下:

 @RequiresPermissions(value={"version:delete","version:delete2"},logical = Logical.OR)
    @GetMapping("/delete/{id}")
    @ResponseBody
    public Result delete(@PathVariable String id){
        versionService.deleteVersion(id);
        return success();
    }

从打印的信息可以看出,当前用户aaa,具有admin的角色,该角色具有[add, query, version:list, version:release, update, delete, version:edit]的权限,但其中并没有version:delete,因此会报错AuthorizationException。

用户: aaa 具有的角色: [admin]
用户: aaa 具有的权限: [add, query, version:list, version:release, update, delete, version:edit]
2018-06-14T18:31:23.180+0800 WEBERROR 8852 --- [nio-8890-exec-5] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.apache.shiro.authz.UnauthorizedException: Subject does not have permission [version:delete]] with root cause

org.apache.shiro.authz.AuthorizationException: Not authorized to invoke method: public com.yealink.microservice.core.result.Result com.yealink.version.controller.VersionController.delete(java.lang.String)
	at org.apache.shiro.authz.aop.AuthorizingAnnotationMethodInterceptor.assertAuthorized(AuthorizingAnnotationMethodInterceptor.java:90)
	at org.apache.shiro.authz.aop.AnnotationsAuthorizingMethodInterceptor.assertAuthorized(AnnotationsAuthorizingMethodInterceptor.java:100)

需求:

项目中可能会有很多的方法都会加上权限注解,当当前角色没有该方法的权限标识时都会抛出这个异常,那么我们自然希望能够对异常进行捕获,并且最好能够对这个异常进行统一的处理,比如返回一个提示的页面,或者返回一点信息给前端。

解决办法:

新建统一异常处理类,@ControllerAdvice注解定义全局异常处理类,@ExceptionHandler注解声明异常处理方法。现在就可以在该类中定义各种不同异常的处理方法。

package com.yealink.version.exception;

import com.yealink.microservice.core.controller.BaseController;
import com.yealink.microservice.core.result.Result;
import org.apache.shiro.authz.AuthorizationException;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;

/**
 * Created by yl1794 on 2018/6/14.
 */
@ControllerAdvice
public class ExceptionAdvice extends BaseController{

    /**
     * 全局捕获AuthorizationException异常,并进行相应处理
     */
    @ExceptionHandler({AuthorizationException.class})
    @ResponseBody
    public Result handleException(Exception e){
//        e.printStackTrace();
        System.out.println("AuthorizationException--------------");
        return success("AuthorizationException");
    }

}

优化后结果:

再次执行delete方法,虽然还是没有权限,但此时已经不报错了,从打印结果来看,确实捕获到了该异常。

用户: aaa 具有的角色: [admin]
用户: aaa 具有的权限: [add, version:list, query, version:release, update, delete, version:edit]
AuthorizationException--------------

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中实现统一异常处理可以通过以下步骤进行操作: 1. 创建一个全局异常处理类:创建一个类,用于处理应用程序中抛出的所有异常。可以命名为GlobalExceptionHandler或类似的名称。 ```java public class GlobalExceptionHandler implements HandlerExceptionResolver { @Override public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { // 在这里处理异常并返回适当的错误响应 return new ModelAndView("error"); // 返回一个自定义的错误页面或其他错误响应 } } ``` 2. 实现HandlerExceptionResolver接口:让全局异常处理类实现HandlerExceptionResolver接口,并实现其中的resolveException()方法。 3. 处理异常并返回错误响应:在resolveException()方法中,根据需要对捕获到的异常进行适当的处理,并返回一个错误响应给客户端。可以是一个自定义的错误页面,或者是一个包含错误信息的JSON对象。 4. 注册全局异常处理器:将全局异常处理器注册到应用程序中,以确保它能够捕获到所有的异常。具体的注册方式取决于所使用的Java框架。 在Spring框架中,可以通过以下方式注册全局异常处理器: ```java @Configuration @EnableWebMvc public class WebConfig implements WebMvcConfigurer { @Override public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) { resolvers.add(new GlobalExceptionHandler()); } } ``` 在Spring Boot框架中,可以通过以下方式注册全局异常处理器: ```java @RestControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(Exception.class) public ResponseEntity<ErrorResponse> handleException(Exception ex) { // 在这里处理异常并返回适当的错误响应 ErrorResponse errorResponse = new ErrorResponse("500", "Internal Server Error"); return new ResponseEntity<>(errorResponse, HttpStatus.INTERNAL_SERVER_ERROR); } } ``` 需要根据具体的需求和框架进行调整和实施。以上是一种常见的实现方式,可以根据自己的需求进行扩展和定制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值