Spring Security自定義異常 AccessDeniedHandler不生效解決方法
【出現(xiàn)場(chǎng)景】
最近在項(xiàng)目中通過Security實(shí)現(xiàn)單點(diǎn)登錄的時(shí)候,發(fā)現(xiàn)明明應(yīng)該觸發(fā) AccessDeniedException 異常,但沒有報(bào)出來,應(yīng)該是報(bào)了GlobalException里面定義的全局異常,發(fā)現(xiàn)是被全局異常捕獲了。項(xiàng)目還原成本有點(diǎn)大 我就先把大體解決流程記錄一下。
【解決思路】
既然發(fā)現(xiàn)是被全局異常捕獲掉了,我們就把思路放到 如何讓異常不被全局異常捕獲,而自己定義異常 進(jìn)行錯(cuò)誤消息的配置呢?
首先新增一個(gè)類
@Component
public class MyAccessDeniedHandler implements AccessDeniedHandler {
private static final ObjectMapper objectMapper=new ObjectMapper();
@Override
public void handle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, AccessDeniedException e) throws IOException, ServletException {
//在這里返回一個(gè)包含著錯(cuò)誤信息的對(duì)象數(shù)據(jù)
JsonResult jsonResult=JsonResult.fail(ServiceCode.ERR_FORBIDDEN, "您無此權(quán)限!");
httpServletResponse.setContentType("application/json;charset=utf-8");
httpServletResponse.getWriter().write(objectMapper.writeValueAsString(jsonResult));
httpServletResponse.flushBuffer();
}
}通過實(shí)現(xiàn)AccessDeniedHandler 接口 重寫的handle 方法進(jìn)行捕獲,AcceseDeniedException異常.
至此 可能就算解決完了?
可能一般項(xiàng)目中 這樣解決就可以了,但是我發(fā)現(xiàn)配置后并沒有生效 ,還是會(huì)被Global里的最高Exception捕獲。
【再次解析】
因?yàn)槲覀兪欠植际降捻?xiàng)目。查閱一些資料后 在實(shí)現(xiàn)單點(diǎn)登錄的項(xiàng)目中新增了如下類
@ControllerAdvice
public class AccessDeniedExceptionHandler {
@ExceptionHandler(AccessDeniedException.class)
public void accessDeniedException(AccessDeniedException e) throws AccessDeniedException{
throw e;
}
}首先 說 @ControllerAdvice注解
@ControllerAdvice 本質(zhì)也是一個(gè)@Component,所以配置上這個(gè)注解 也會(huì)被當(dāng)成組件掃描

簡(jiǎn)要說明一下該注解的意思。簡(jiǎn)單來說 他就是一個(gè)攔截類,在@ExcepitonHandler 或 @ModelAttribute注解修飾的)方法的類而提供的專業(yè)化的Component, 以供多個(gè)Controller類所共享。簡(jiǎn)單來理解 就是AOP的思想的注解實(shí)現(xiàn),咱們通過@ExceptionHandler注解 配置好規(guī)則,ControllerAdvice就會(huì)幫咱們進(jìn)行攔截。
默認(rèn)情況下 如果@ControllerAdvice什么都不寫 就是攔截所有controller 。如果想指定包攔截 可以這樣寫 @ControllerAdvice(basePackages = "com.xxx.controller")進(jìn)行指定包的攔截。
接下來看@ExceptionHandler注解
簡(jiǎn)單來說 就是對(duì)指定的異常 進(jìn)行處理。
@ExceptionHandler 注解 是要和 @ControllerAdvice 注解搭配到一起用的。

可以看到 ExceptionHandler里面的參數(shù) 只有一個(gè)Throwable ,這也就是說他可以接收任何Throwable類型的異常。 使用方法如我上面所示這樣 @ExceptionHandler(AccessDeniedException.class)進(jìn)行配置即可
這樣就是進(jìn)行 AccessDeniedException 異常的攔截。
說回正文,在我的項(xiàng)目中添加完@ControllerAdvice注解的這個(gè)類后,報(bào)異常時(shí)就不會(huì)再走 GlobalException 全局配置的異常了,深層次的原因我沒有深挖,我覺得應(yīng)該是本項(xiàng)目中配置的@ControllerAdvice注解要晚于Global的包@ControllerAdvice的加載時(shí)間吧。
配置完這個(gè)類后,第一個(gè)MyAccessDeniedHandler 類就發(fā)現(xiàn)起了作用了。
到此這篇關(guān)于Spring Security自定義異常 AccessDeniedHandler不生效解決方法的文章就介紹到這了,更多相關(guān)Spring Security AccessDeniedHandler不生效內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于Java+SSM實(shí)現(xiàn)電影院購(gòu)票系統(tǒng)
今天小編給大家?guī)硪豢頢SM的電影院售票系統(tǒng),非常不錯(cuò)的一個(gè)項(xiàng)目,是學(xué)習(xí)?javaweb編程必備。文中的示例代碼講解詳細(xì),需要的可以參考一下2022-04-04
Spring常用注解 使用注解來構(gòu)造IoC容器的方法
下面小編就為大家分享一篇Spring常用注解 使用注解來構(gòu)造IoC容器的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-01-01
淺析Java的Hibernate框架中的繼承關(guān)系設(shè)計(jì)
這篇文章主要介紹了Java的Hibernate框架中的繼承關(guān)系設(shè)計(jì),Hibernate是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下2015-12-12
使用mybatis的typeHandler對(duì)clob進(jìn)行流讀寫方式
這篇文章主要介紹了使用mybatis的typeHandler對(duì)clob進(jìn)行流讀寫方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
使用Java進(jìn)行Json數(shù)據(jù)的解析(對(duì)象數(shù)組的相互嵌套)
下面小編就為大家?guī)硪黄褂肑ava進(jìn)行Json數(shù)據(jù)的解析(對(duì)象數(shù)組的相互嵌套)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
springboot實(shí)現(xiàn)發(fā)送QQ郵箱
這篇文章主要為大家詳細(xì)介紹了springboot實(shí)現(xiàn)發(fā)送QQ郵箱,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
springboot自定義配置及自定義對(duì)象映射的全流程
這篇文章主要介紹了springboot自定義配置及自定義對(duì)象映射的全流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10

