Sa-Token 使用笔记(二)------ 全局异常处理

本文介绍了在Spring Boot项目中如何实现全局异常处理,通过@ControllerAdvice和@RestControllerAdvice进行区分,详细讲述了不同Controller类型的异常处理方式,并分享了在配置类优先级上的踩坑经验,强调了配置类的加载顺序对异常处理的影响。
摘要由CSDN通过智能技术生成

背景

项目中,Controller分一般的视图控制器和RestController两种,前者主要面向有显示需求的浏览器用户,后者则主要面向接口使用者。异常反馈的形式也因此有所区分。

实现方式

  1. 利用 @ControllerAdvice 实现全局异常处理
  2. 利用 @ControllerAdvice 的 “basePackages”属性,作针对性区分

操作示例

  1. 针对两种Controller,作物理上的区分,即建立“CommonController”和“RestController”包,来分别放置。
  2. 针对两个包,分别建立异常处理类:
// 返回视图(需搭配页面模板 /error)

@Slf4j
@ControllerAdvice("xxx.CommonController")
public class GlobalExceptionHandlerForCommon {
   

	// 全局异常拦截
	@ExceptionHandler
	public String handlerExceptions(Model model, RedirectAttributes attrs, Exception e, HttpServletRequest request) {
   
	
		log.info("全局异常---------------");
		e.printStackTrace();
	
		// 判断场景值,定制化异常信息
		String msg;
		if (e instanceof NotLoginException) {
                      // 如果是未登录异常
			// NotLoginException ee = (NotLoginException) e;
			//  msg = "未登录:" + ee.getMessage();
		    attrs.addFlashAttribute("msg","Please login");
		    attrs.addFlashAttribute("lastUrl",request.getRequestURL());
		    return "redirect:/login";
		} else if (e instanceof NotRoleException) {
                // 如果是角色异常
		    NotRoleException ee = (NotRoleException) e;
		    msg = "无此角色:" + ee.getRole
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值