springmvc用于方法鑒權(quán)的注解攔截器的解決方案代碼
最近在用SpringMvc寫項目的時候,遇到一個問題,就是方法的鑒權(quán)問題,這個問題弄了一天了終于解決了,下面看下解決方法
項目需求:需要鑒權(quán)的地方,我只需要打個標(biāo)簽即可,比如只有用戶登錄才可以進(jìn)行的操作,一般情況下我們會在執(zhí)行方法時先對用戶的身份進(jìn)項校驗,這樣無形中增加了非常大的工作量,重復(fù)造輪子,有了java注解只需要在需要鑒權(quán)的方法上面打個標(biāo)簽即可:
解決方案:
1、首先創(chuàng)建一個注解類:
@Documented @Inherited @Target({ElementType.METHOD,ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) public @interface Auth { boolean validate() default true; }
2、再創(chuàng)建一個攔截器:
public class AuthInterceptor extends BaseInterceptor{ @Override public Boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if(handler.getClass().isAssignableFrom(HandlerMethod.class)){ Auth authPassport = ((HandlerMethod) handler).getMethodAnnotation(Auth.class); //沒有聲明需要權(quán)限,或者聲明不驗證權(quán)限 if(authPassport==null){ return true; } else{ //在這里實現(xiàn)自己的權(quán)限驗證邏輯 if(true){ //如果驗證成功返回true(這里直接寫false來模擬驗證失敗的處理) System.out.println("執(zhí)行權(quán)限校驗了"); return true; } else{ //如果驗證失敗 //返回到登錄界面 // System.out.println("權(quán)限校驗對了"); // response.sendRedirect("account/login"); return false; } } } else{ return true; } } }
3、配置攔截器:需要在*-servlet.xml里面增加以下代碼,如果您自定義了配置文件也可直接放到您定義的配置文件中
<mvc:interceptors> <bean class="com.benxq.shop.user.interceptors.AuthInterceptor"/> </mvc:interceptors>
注意:需要將默認(rèn)的改為RequestMappingHandlerMapping,增加RequestMappingHandlerAdapter的bean
重新啟動tomcat即可,
溫馨提示:如果對方法需要鑒權(quán)只需要在方法上面打上@Auth,如果對類的所有方法需要鑒權(quán),只需要在類上面打上@Auth即可。
那么問題來了,方法攔截器會吧靜態(tài)資源一塊攔截,我們需要在tomcat中進(jìn)行對靜態(tài)文件進(jìn)行攔截如:我的解決方法是在web.xml進(jìn)行配置,大家有好的方法也可以加我扣扣752432995一塊探討
<servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.jpg</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.png</url-pattern> </servlet-mapping>
總結(jié)
以上就是本文關(guān)于springmvc用于方法鑒權(quán)的注解攔截器的解決方案代碼的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
SpringMVC攔截器實現(xiàn)單點(diǎn)登錄
SpringMVC攔截器實現(xiàn)監(jiān)聽session是否過期詳解
如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
SpringMVC?RESTFul實戰(zhàn)案例修改功能實現(xiàn)
這篇文章主要為大家介紹了SpringMVC?RESTFul實戰(zhàn)案例修改功能實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Spring?Boot集成validation實現(xiàn)參數(shù)校驗功能
Bean?Validation?是一個運(yùn)行時的數(shù)據(jù)驗證框架,在驗證之后驗證的錯誤信息會被馬上返回,這篇文章主要介紹了Spring?Boot集成validation實現(xiàn)參數(shù)校驗功能,需要的朋友可以參考下2024-05-05如何基于mybatis框架查詢數(shù)據(jù)庫表數(shù)據(jù)并打印
這篇文章主要介紹了如何基于mybatis框架查詢數(shù)據(jù)庫表數(shù)據(jù)并打印,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11springboot中手動提交事務(wù)的實現(xiàn)方法
手動提交事務(wù)可以提供更靈活的控制,以便在分布式環(huán)境中處理事務(wù)的提交和回滾,本文就來介紹一下springboot中手動提交事務(wù)的實現(xiàn)方法,感興趣的可以了解一下2024-01-01SpringBoot實現(xiàn)郵件任務(wù)的步驟詳解
這篇文章主要介紹了SpringBoot實現(xiàn)郵件任務(wù)的步驟詳解,使用Spring Boot實現(xiàn)QQ郵箱發(fā)送郵件具有快速集成、統(tǒng)一的開發(fā)體驗、強(qiáng)大的維護(hù)和擴(kuò)展能力、可靠的送達(dá)性和安全性等優(yōu)勢,可以幫助你快速構(gòu)建穩(wěn)定可靠的郵件發(fā)送功能,需要的朋友可以參考下2023-10-10SpringCloud微服務(wù)熔斷器Hystrix使用詳解
這篇文章主要介紹了Spring Cloud Hyxtrix的基本使用,它是Spring Cloud中集成的一個組件,在整個生態(tài)中主要為我們提供服務(wù)隔離,服務(wù)熔斷,服務(wù)降級功能,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07