前言
日誌處理是每個項目當中一個非常重要的內容。沒有了日誌,也就失去了對系統的可控性。沒有日誌,系統出現任何問題,都會沒有踪跡可尋,這對一個信息系統而言是非常危險的。
項目中需要將service中的類方法的調用過程,使用log4j日誌記錄。
service中的類和方法都很多,不可能在每個類中單獨添加log4j日誌記錄的功能,因此我們在這裡使用AOP的思想進行橫向切面。
以service類中的方法為切入點,通過AOP在方法調用前後使用log4j輸出日誌,內容包括正在調用的類和方法名。
在配置過程中,筆者碰到了一些或大或小的細節上的問題,在此作為記錄。
首先是AOP的配置上,我們有兩種選擇,一是通過XML配置,二是通過註解。
XML配置可以通過以下示例:
XML配置
則對應的Aspect方法可以不用使用@Aspect、@Before和@After註解。
如果使用註解方式,則在XML配置文件中,只需要一行配置,開啟自動代理功能即可:
自動代理
此時,對應的Aspect方法可以如下示例:
Aspect1
其次,是Spring配置文件所屬域上的坑,在這裡配置的AOP的XML文件,如果需要成功執行,需要在
web.xml文件中,將此XML配置文件加入到Servlet-Context中,而不是Spring-Context中,示例如下:
全局context
上圖是配置全局的spring上下文,但是aop配置文件在這裡不能成功。
Servlet的context
我們需要把aop的配置加載,放在servlet的初始化上下文中。
最後,我們運行工程,使用該方法,查看AOP結果:
結果
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。