springmvc用于方法鑒權(quán)的注解攔截器的解決方案代碼
最近在用SpringMvc寫項(xiàng)目的時(shí)候,遇到一個(gè)問題,就是方法的鑒權(quán)問題,這個(gè)問題弄了一天了終于解決了,下面看下解決方法
項(xiàng)目需求:需要鑒權(quán)的地方,我只需要打個(gè)標(biāo)簽即可,比如只有用戶登錄才可以進(jìn)行的操作,一般情況下我們會在執(zhí)行方法時(shí)先對用戶的身份進(jìn)項(xiàng)校驗(yàn),這樣無形中增加了非常大的工作量,重復(fù)造輪子,有了java注解只需要在需要鑒權(quán)的方法上面打個(gè)標(biāo)簽即可:

解決方案:
1、首先創(chuàng)建一個(gè)注解類:
@Documented
@Inherited
@Target({ElementType.METHOD,ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface Auth {
boolean validate() default true;
}
2、再創(chuàng)建一個(gè)攔截器:
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)限,或者聲明不驗(yàn)證權(quán)限
if(authPassport==null){
return true;
} else{
//在這里實(shí)現(xiàn)自己的權(quán)限驗(yàn)證邏輯
if(true){
//如果驗(yàn)證成功返回true(這里直接寫false來模擬驗(yàn)證失敗的處理)
System.out.println("執(zhí)行權(quán)限校驗(yàn)了");
return true;
} else{
//如果驗(yàn)證失敗
//返回到登錄界面
// System.out.println("權(quán)限校驗(yà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
重新啟動(dòng)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攔截器實(shí)現(xiàn)單點(diǎn)登錄
SpringMVC攔截器實(shí)現(xiàn)監(jiān)聽session是否過期詳解
如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
Java方法的參數(shù)傳遞機(jī)制實(shí)例詳解
這篇文章主要介紹了Java方法的參數(shù)傳遞機(jī)制,結(jié)合實(shí)例形式詳細(xì)分析了java方法參數(shù)傳遞機(jī)制原理、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2019-09-09
Spring session實(shí)現(xiàn)Session共享
本文主要介紹了Spring session實(shí)現(xiàn)Session共享,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
基于Spring Data的AuditorAware審計(jì)功能的示例代碼
這篇文章主要介紹了基于Spring Data的AuditorAware審計(jì)功能的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03
XML Web 服務(wù) Eclipse實(shí)現(xiàn)sun-jaxws.xml文件的方法
在sun-jaxws.xml文件,可以配置endpoint、handler-chain等內(nèi)容,在這個(gè)文件中配置的內(nèi)容會覆蓋在Java代碼中使用注解屬性配置的的內(nèi)容,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2023-11-11

