spring aop action中驗證用戶登錄狀態(tài)的實例代碼
最近在學習ssh框架時,照著網(wǎng)上做了一個商城系統(tǒng),之前在一些需要用戶存在的操作中,都是在每一個action中寫重復(fù)的代碼,這樣做現(xiàn)在想起來并不好,想起了spring的aop,于是想通過aop來給每個需要用戶操作的Action驗證用戶登錄狀態(tài)。
想法是這樣的:
1. 用戶登錄時把userId放入session中
2. 通過spring 寫一個advice來獲取session中的userId,判斷用戶登錄狀態(tài),如果userId不符合,則拋出自定義異常
3. 通過struts中配置來捕獲異常,跳轉(zhuǎn)界面
以下是代碼:
advice代碼:
public class IsUserLoginAdvice{ public void isUserLogin() throws UserNotFoundException{ // TODO Auto-generated method stub int id=0; Map sessionMap=ActionContext.getContext().getSession(); System.out.println(sessionMap); try { //這里在一開始時userId是不存在的可能會拋出NullPointException,catch起來 id=(int) sessionMap.get("userId"); //在用戶注銷時我把session中的userId設(shè)為0 if(id==0){ throw new UserNotFoundException(); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); throw new UserNotFoundException(); } } }
struts.xml:
這里通過全局異常映射來處理這個異常:
<package name="struts-global" namespace="/" extends="struts-default"> <global-results> <result name="userNotFound">/web_resource/error_jsp/user_not_found.jsp </result> </global-results> <global-exception-mappings> <exception-mapping result="userNotFound" exception="com.lsj.market.exception.UserNotFoundException"></exception-mapping> </global-exception-mappings> </package>
全局異常有個name屬性,給那些想要共享該異常捕獲的package繼承,這樣就可以共享該異常捕獲行為:
<package name="com.lsj.market.action.user" extends="struts-global">
applicationContext.xml:
<!-- aop設(shè)置 --> <aop:config proxy-target-class="true"> <aop:aspect ref="isUserLoginAdvice"> <aop:pointcut id="isUserLoginPointcut" expression="execution (* com.lsj.market.action..GetUser*.*(..)) or execution (* com.lsj.market.action..*Update*Action*.*(..)) or execution (* com.lsj.market.action..*Delete*Action*.*(..)) or execution (* com.lsj.market.action..GetMarketCar*.*(..)) or execution (* com.lsj.market.action..MarketCar*.*(..)) or execution (* com.lsj.market.action..ToFlower*.*(..)) or execution (* com.lsj.market.action..Flower*Add*.*(..))"/> <aop:before method="isUserLogin" pointcut-ref="isUserLoginPointcut"/> </aop:aspect> </aop:config> <!-- 聲明advice Bean --> <bean id="isUserLoginAdvice" class="com.lsj.market.aop.IsUserLoginAdvice"></bean>
其中pointcut可以通過or 來連接多個切入點,這里有這么多切入點是因為第一次做,沒想到用aop,各個Action的命名沒有考慮太多,導(dǎo)致現(xiàn)在必須配置這么多個切入點表達式- -!!!
還有一個,如果struts交由spring管理時,即struts.xml中配置了這一句:
<constant name="struts.objectFactory" value="spring" />
在生成代理類時會發(fā)生錯誤,無法捕捉到拋出的異常,在網(wǎng)上查了后發(fā)現(xiàn)需要在struts.xml加入這一句,struts就可以捕捉到該異常了:
<!-- 總是確保使用spring的自動裝備策略 --> <constant name="struts.objectFactory.spring.autoWire.alwaysRespect" value="true" />
剛剛還想刪除這一句配置后把異常發(fā)上來,但是發(fā)現(xiàn)刪除后居然還可以運行?!
算了還是寫上來,以后遇到這個問題,還可以看一下博客。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java System.currentTimeMillis()時間的單位轉(zhuǎn)換與計算方式案例詳解
這篇文章主要介紹了Java System.currentTimeMillis()時間的單位轉(zhuǎn)換與計算方式案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08Java常見基礎(chǔ)數(shù)據(jù)結(jié)構(gòu)
這篇文章主要介紹了Java常見數(shù)據(jù)結(jié)構(gòu)面試題,帶有答案及解釋,希望對廣大的程序愛好者有所幫助,同時祝大家有一個好成績,需要的朋友可以參考下,希望可以幫助到你2021-07-07Java guava monitor監(jiān)視器線程的使用詳解
工作中的場景中是否存在類似這樣的場景,需要提交的線程在某個觸發(fā)條件下執(zhí)行。本文主要就是使用guava中的monitor來優(yōu)雅的實現(xiàn)帶監(jiān)視器的線程2021-11-11jsp+servlet實現(xiàn)簡單登錄頁面功能(附demo)
本文主要介紹了jsp+servlet實現(xiàn)簡單登錄頁面功能登錄成功跳轉(zhuǎn)新頁面,登錄失敗在原登錄界面提示登錄失敗信息,對初學者有一定的幫助,感興趣的可以了解一下2021-07-07springcloud中RabbitMQ死信隊列與延遲交換機實現(xiàn)方法
死信隊列是消息隊列中非常重要的概念,同時我們需要業(yè)務(wù)場景中都需要延遲發(fā)送的概念,比如12306中的30分鐘后未支付訂單取消,那么本期,我們就來講解死信隊列,以及如何通過延遲交換機來實現(xiàn)延遲發(fā)送的需求,感興趣的朋友一起看看吧2022-05-05Java設(shè)計模式之備忘錄模式_動力節(jié)點Java學院
我們在編程的時候,經(jīng)常需要保存對象的中間狀態(tài),當需要的時候,可以恢復(fù)到這個狀態(tài)。接下來通過本文給大家分享java設(shè)計模式之備忘錄模式,感興趣的的朋友一起看看吧2017-08-08