最近在用SpringMvc寫項目的時候,遇到一個問題,就是方法的鑑權問題,這個問題弄了一天了終於解決了,下面看下解決方法
項目需求:需要鑑權的地方,我只需要打個標籤即可,比如只有用戶登錄才可以進行的操作,一般情況下我們會在執行方法時先對用戶的身份進項校驗,這樣無形中增加了非常大的工作量,重複造輪子,有了java註解只需要在需要鑑權的方法上面打個標籤即可:
解決方案:
1、首先創建一個註解類:
@Documented@Inherited@Target({ElementType.METHOD,ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)public @interface Auth { boolean validate() default true;}2、再創建一個攔截器:
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);//沒有聲明需要權限,或者聲明不驗證權限if(authPassport==null){return true;} else{//在這裡實現自己的權限驗證邏輯if(true){//如果驗證成功返回true(這裡直接寫false來模擬驗證失敗的處理)System.out.println("執行權限校驗了");return true;} else{//如果驗證失敗//返回到登錄界面// System.out.println("權限校驗對了");// response.sendRedirect("account/login");return false;}}} else{return true;}}}3、配置攔截器:需要在*-servlet.xml裡面增加以下代碼,如果您自定義了配置文件也可直接放到您定義的配置文件中
<mvc:interceptors><bean/></mvc:interceptors>
注意:需要將默認的改為RequestMappingHandlerMapping,增加RequestMappingHandlerAdapter的bean
重新啟動tomcat即可,
溫馨提示:如果對方法需要鑑權只需要在方法上面打上@Auth,如果對類的所有方法需要鑑權,只需要在類上面打上@Auth即可。
那麼問題來了,方法攔截器會吧靜態資源一塊攔截,我們需要在tomcat中進行對靜態文件進行攔截如:我的解決方法是在web.xml進行配置,大家有好的方法也可以加我扣扣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>
總結
以上就是本文關於springmvc用於方法鑑權的註解攔截器的解決方案代碼的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站:
SpringMVC攔截器實現單點登錄
SpringMVC攔截器實現監聽session是否過期詳解
如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!