shiro 无法跳转到unauthorizedUrl

问题:shiro框架控制用户权限,用户权限认证未通过时,无法跳转到unauthorizedUrl对应的页面,直接抛出了异常。


原因:

  1. private void applyUnauthorizedUrlIfNecessary(Filter filter) {  
  2.     String unauthorizedUrl = getUnauthorizedUrl();  
  3.     if (StringUtils.hasText(unauthorizedUrl) && (filter instanceof AuthorizationFilter)) {  
  4.         AuthorizationFilter authzFilter = (AuthorizationFilter) filter;  
  5.         //only apply the unauthorizedUrl if they haven't explicitly configured one already:  
  6.         String existingUnauthorizedUrl = authzFilter.getUnauthorizedUrl();  
  7.         if (existingUnauthorizedUrl == null) {  
  8.             authzFilter.setUnauthorizedUrl(unauthorizedUrl);  
  9.         }  
  10.     }  
定义的filter必须满足filter instanceof AuthorizationFilter,只有perms,roles,ssl,rest,port才是属于AuthorizationFilter,而anon,authcBasic,auchc,user是AuthenticationFilter,所以unauthorizedUrl设置后页面不跳转

解决方案:

方案一:

<error-page>
<exception-type>org.apache.shiro.authz.UnauthorizedException</exception-type>
<location>/unauthorized.jsp</location>
</error-page>

方案二:使用perms,roles,ssl,rest,port

方案三:使用@ExceptionHandler(UnauthorizedException.class)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值