Spring Security自定義異常 AccessDeniedHandler不生效解決方法
【出現(xiàn)場(chǎng)景】
最近在項(xiàng)目中通過(guò)Security實(shí)現(xiàn)單點(diǎn)登錄的時(shí)候,發(fā)現(xiàn)明明應(yīng)該觸發(fā) AccessDeniedException 異常,但沒有報(bào)出來(lái),應(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, "您無(wú)此權(quán)限!"); httpServletResponse.setContentType("application/json;charset=utf-8"); httpServletResponse.getWriter().write(objectMapper.writeValueAsString(jsonResult)); httpServletResponse.flushBuffer(); } }
通過(guò)實(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; } }
首先 說(shuō) @ControllerAdvice注解
@ControllerAdvice 本質(zhì)也是一個(gè)@Component,所以配置上這個(gè)注解 也會(huì)被當(dāng)成組件掃描
簡(jiǎn)要說(shuō)明一下該注解的意思。簡(jiǎn)單來(lái)說(shuō) 他就是一個(gè)攔截類,在@ExcepitonHandler 或 @ModelAttribute注解修飾的)方法的類而提供的專業(yè)化的Component, 以供多個(gè)Controller類所共享。簡(jiǎn)單來(lái)理解 就是AOP的思想的注解實(shí)現(xiàn),咱們通過(guò)@ExceptionHandler注解 配置好規(guī)則,ControllerAdvice就會(huì)幫咱們進(jìn)行攔截。
默認(rèn)情況下 如果@ControllerAdvice什么都不寫 就是攔截所有controller 。如果想指定包攔截 可以這樣寫 @ControllerAdvice(basePackages = "com.xxx.controller")進(jìn)行指定包的攔截。
接下來(lái)看@ExceptionHandler注解
簡(jiǎn)單來(lái)說(shuō) 就是對(duì)指定的異常 進(jìn)行處理。
@ExceptionHandler 注解 是要和 @ControllerAdvice 注解搭配到一起用的。
可以看到 ExceptionHandler里面的參數(shù) 只有一個(gè)Throwable ,這也就是說(shuō)他可以接收任何Throwable類型的異常。 使用方法如我上面所示這樣 @ExceptionHandler(AccessDeniedException.class)進(jìn)行配置即可
這樣就是進(jìn)行 AccessDeniedException 異常的攔截。
說(shuō)回正文,在我的項(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ī)?lái)一款SSM的電影院售票系統(tǒng),非常不錯(cuò)的一個(gè)項(xiàng)目,是學(xué)習(xí)?javaweb編程必備。文中的示例代碼講解詳細(xì),需要的可以參考一下2022-04-04Spring常用注解 使用注解來(lái)構(gòu)造IoC容器的方法
下面小編就為大家分享一篇Spring常用注解 使用注解來(lái)構(gòu)造IoC容器的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01淺析Java的Hibernate框架中的繼承關(guān)系設(shè)計(jì)
這篇文章主要介紹了Java的Hibernate框架中的繼承關(guān)系設(shè)計(jì),Hibernate是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下2015-12-12RestTemplate添加HTTPS證書全過(guò)程解析
這篇文章主要介紹了RestTemplate添加HTTPS證書全過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10使用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ī)?lái)一篇使用Java進(jìn)行Json數(shù)據(jù)的解析(對(duì)象數(shù)組的相互嵌套)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08springboot實(shí)現(xiàn)發(fā)送QQ郵箱
這篇文章主要為大家詳細(xì)介紹了springboot實(shí)現(xiàn)發(fā)送QQ郵箱,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06springboot自定義配置及自定義對(duì)象映射的全流程
這篇文章主要介紹了springboot自定義配置及自定義對(duì)象映射的全流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10