标签:aspect eth 编译 注解 ntc sys java 代码 源代码
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.2.0.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>5.2.0.RELEASE</version> <scope>test</scope> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.17</version> </dependency> <dependency> <groupId>commons-dbutils</groupId> <artifactId>commons-dbutils</artifactId> <version>1.7</version> </dependency> <dependency> <groupId>com.mchange</groupId> <artifactId>c3p0</artifactId> <version>0.9.5.4</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>5.2.0.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aspects</artifactId> <version>5.2.0.RELEASE</version> </dependency> <dependency> <groupId>aopalliance</groupId> <artifactId>aopalliance</artifactId> <version>1.0</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.9.4</version> </dependency>
package com.sunxiaping.spring5.log; /** * 日志,即通知 */ public class LogUtils { /** * 开始打印日志 */ public void startLog() { System.out.println("****开始打印日志****"); } /** * 结束打印日志 */ public void endLog() { System.out.println("****结束打印日志****"); } }
package com.sunxiaping.spring5.service; public interface IAccountService { /** * 新增 */ void save(); /** * 更新 */ void update(); }
package com.sunxiaping.spring5.service.impl; import com.sunxiaping.spring5.service.IAccountService; public class AccountServiceImpl implements IAccountService { @Override public void save() { System.out.println("新增"); } @Override public void update() { System.out.println("根据"); } }
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"> <!-- 配置业务层 --> <bean id="accountService" class="com.sunxiaping.spring5.service.impl.AccountServiceImpl"/> <!-- 配置通知 --> <bean id="log" class="com.sunxiaping.spring5.log.LogUtils"></bean> <!-- 配置aop--> <aop:config> <!-- 配置切入点表达式--> <aop:pointcut id="pointcut" expression="execution(* com.sunxiaping.spring5.service.*.*(..))"/> <!-- 配置切面 id:给切面提供一个唯一的id ref:引用配置好的通知类Bean的id --> <aop:aspect ref="log"> <!-- 前置通知 --> <aop:before method="startLog" pointcut-ref="pointcut"/> <!-- 后置通知 --> <aop:after method="endLog" pointcut-ref="pointcut"/> </aop:aspect> </aop:config> </beans>
package com.sunxiaping; import com.sunxiaping.spring5.service.IAccountService; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "classpath:applicationContext.xml") public class spring5Test { @Autowired private IAccountService accountService; @Test public void test() { accountService.save(); } }
package com.sunxiaping.spring5.service; public interface IAccountService { /** * 新增 */ void save(); /** * 更新 */ void update(); }
package com.sunxiaping.spring5.service.impl; import com.sunxiaping.spring5.service.IAccountService; import org.springframework.stereotype.Service; @Service public class AccountServiceImpl implements IAccountService { @Override public void save() { System.out.println("新增"); } @Override public void update() { System.out.println("根据"); } }
package com.sunxiaping.spring5.log; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.stereotype.Component; /** * 日志,即通知 */ @Component @Aspect //表明是一个通知类 public class LogUtils { @Pointcut("execution(* com.sunxiaping.spring5.service.*.*(..))") public void pointcut() { } /** * 开始打印日志 */ @Before("pointcut()") public void startLog() { System.out.println("****开始打印日志****"); } /** * 结束打印日志 */ @After("pointcut()") public void endLog() { System.out.println("****结束打印日志****"); } }
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"> <context:component-scan base-package="com.sunxiaping.spring5"/> <!--开启Spring对注解AOP的支持--> <aop:aspectj-autoproxy/> </beans>
package com.sunxiaping; import com.sunxiaping.spring5.service.IAccountService; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "classpath:applicationContext.xml") public class spring5Test { @Autowired private IAccountService accountService; @Test public void test() { accountService.save(); } }
package com.sunxiaping.spring5.service; public interface IAccountService { /** * 新增 */ void save(); /** * 更新 */ void update(); }
package com.sunxiaping.spring5.service.impl; import com.sunxiaping.spring5.service.IAccountService; import org.springframework.stereotype.Service; @Service public class AccountServiceImpl implements IAccountService { @Override public void save() { System.out.println("新增"); } @Override public void update() { System.out.println("根据"); } }
package com.sunxiaping.spring5.log; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.stereotype.Component; /** * 日志,即通知 */ @Component @Aspect //表明是一个通知类 public class LogUtils { @Pointcut("execution(* com.sunxiaping.spring5.service.*.*(..))") public void pointcut() { } /** * 开始打印日志 */ @Before("pointcut()") public void startLog() { System.out.println("****开始打印日志****"); } /** * 结束打印日志 */ @After("pointcut()") public void endLog() { System.out.println("****结束打印日志****"); } }
package com.sunxiaping.spring5.config; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.EnableAspectJAutoProxy; @Configuration @ComponentScan(basePackages = "com.sunxiaping.spring5") @EnableAspectJAutoProxy public class SpringConfiguration { }
package com.sunxiaping; import com.sunxiaping.spring5.config.SpringConfiguration; import com.sunxiaping.spring5.service.IAccountService; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = SpringConfiguration.class) public class spring5Test { @Autowired private IAccountService accountService; @Test public void test() { accountService.save(); } }
标签:aspect eth 编译 注解 ntc sys java 代码 源代码
原文地址:https://www.cnblogs.com/xuweiweiwoaini/p/11747263.html