1、spring的依赖包配置
* SPRING_HOME/dist/spring.jar
* SPRING_HOME/lib/log4j/log4j-1.2.14.jar
* SPRING_HOME/lib/jakarta-commons/commons-logging.jar
* SPRING_HOME/lib/aspectj/*.jar
2、具体配置
<bean id="securityHandler2" class="com.mwh.spring.SecurityHandler2"/>
<aop:config>
<aop:aspect id="securityAspect" ref="securityHandler2">
<aop:pointcut id="addAddMethod" expression="execution(* add*(..))"/>
<aop:before method="checkSecurity" pointcut-ref="addAddMethod"/>
</aop:aspect>
</aop:config>
可以采用Advice中添加一个JoinPoint参数,取得客户端调用的方法名称及参数值
package com.mwh.spring;
import org.aspectj.lang.JoinPoint;
public class SecurityHandler2 {
private void checkSecurity(JoinPoint joinPoint){
for(int i=0;i<joinPoint.getArgs().length;i++){
System.out.println("参数"+joinPoint.getArgs()[i]);
}
System.out.println("方法名:"+joinPoint.getSignature().getName());
System.out.println("检查安全性");
};
}
测试方法
public static void main(String[] args) {
BeanFactory factory=new ClassPathXmlApplicationContext("applicationContext-*.xml");
UserManager userManager=(UserManager) factory.getBean("userManager");
System.out.println("------");
userManager.find("mwh");
}
IuserManager.java
package com.mwh.service.imp;
import java.util.Date;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import com.mwh.domain.Log;
import com.mwh.domain.User;
import com.mwh.service.LogManager;
import com.mwh.service.UserManager;
public class IuserManager extends HibernateDaoSupport implements UserManager{
private LogManager logManager;
public void add(User user) {
System.out.println("执行---IuserManager.add()");
}
public void find(String id) {
System.out.println("find"+id);
}
}
测试类:
public static void main(String[] args) {
BeanFactory factory=new ClassPathXmlApplicationContext("applicationContext-*.xml");
UserManager userManager=(UserManager) factory.getBean("userManager");
System.out.println("------");
userManager.find("mwh");
}
结果:
------参数mwh
方法名:find
检查安全性
findmwh
3、了解表达式的基本语法:
* 匹配返回值
* 匹配包
* 匹配方法
* 匹配参数