Spring---->采用静态配置文件方式实现AOP

本文详细介绍了如何使用Spring框架实现面向切面编程(AOP),包括依赖库配置、核心配置代码、例子代码以及实际应用示例。通过配置文件方式实现了针对特定方法的安全性检查,展示了如何在方法调用前后添加自定义逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

spring对AOP的支持(采用配置文件的方式)

1、spring依赖库
              SPRING_HOME/dist/spring.jar
              SPRING_HOME/lib/jakarta-commons/commons-logging.jar
              SPRING_HOME/lib/log4j/log4j-1.2.14.jar
              SPRING_HOME/lib/aspectj/*.jar
2、配置如下

<aop:config>
		<aop:aspect id="security" ref="securityHandler">
			<aop:pointcut id="allAddMethod" expression="execution(* com.bjsxt.spring.UserManagerImpl.add*(..))"/>
			<aop:before method="checkSecurity" pointcut-ref="allAddMethod"/>
		</aop:aspect>
	</aop:config>	
		

二、例子代码

UserManager.java

package com.ncepu.spring;


public interface UserManager {
	public void add(String name,String password);
	public void delete(int id);
	public void modify(String name,String password);
	public void find (int id);
}

UserManagerImpl.java

package com.ncepu.spring;

public class UserManagerImpl implements UserManager {

	@Override
	public void add(String name, String password) {
	System.out.print("添加用户");

	}

	@Override
	public void delete(int id) {
		System.out.print("删除用户");

	}

	@Override
	public void find(int id) {
		System.out.print("查找用户");
	}

	@Override
	public void modify(String name, String password) {
		System.out.print("修改用户");

	}

}

SecurityHandler.java

package com.ncepu.spring;



public class SecurityHandler {

	private void checkSecurity() {
		System.out.println("安全性检查");
	}

}

我们可以通过Advice中添加一个JoinPoint参数,这个值会由spring自动传入,从JoinPoint中可以取得参数值、方法名等等

package com.ncepu.spring;

import org.aspectj.lang.JoinPoint;


public class SecurityHandler {

	private void checkSecurity(JoinPoint jointpoint) {
		Object[] args=jointpoint.getArgs();
		
		for(int i=0;i<args.length;i++)
			System.out.println(args[i]);
		System.out.println(jointpoint.getSignature().getName());
		System.out.println(jointpoint.getTarget());
		System.out.println("安全性检查");
	}

}

Client.java

package com.ncepu.client;

import org.springframework.beans.factory.BeanFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.ncepu.spring.UserManager;

public class Client {
	
	public static void main(String args[])
	{
		BeanFactory factory=new ClassPathXmlApplicationContext("applicationContext.xml");
		UserManager userManager=(UserManager)factory.getBean("usermanager");
		userManager.add("wsz","ncepu");
	}

}

applicationContext.xml

	<bean id="usermanager" class="com.ncepu.spring.UserManagerImpl"></bean>
	<bean id="securityHandler" class="com.ncepu.spring.SecurityHandler"></bean>

	<aop:config>
		<aop:aspect id="security" ref="securityHandler">
			<aop:pointcut id="allAddMethod"
				expression="execution(* com.ncepu.spring.UserManagerImpl.add*(..))" />
			<aop:before method="checkSecurity" pointcut-ref="allAddMethod" />
		</aop:aspect>
	</aop:config>




 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值