一、创建maven项目springAOP

pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.sheng.example</groupId><artifactId>springAOP</artifactId><packaging>war</packaging><version>1.0-SNAPSHOT</version><name>springAOP Maven Webapp</name><url>http://maven.apache.org</url><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><hibernate.version>5.1.0.Final</hibernate.version><spring.version>4.3.2.RELEASE</spring.version></properties><dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-core</artifactId><version>${hibernate.version}</version></dependency><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-ehcache</artifactId><version>${hibernate.version}</version></dependency><!-- 二级缓存ehcache --><dependency><groupId>net.sf.ehcache</groupId><artifactId>ehcache</artifactId><version>2.10.1</version></dependency><!--Spring--><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring.version}</version><scope>test</scope></dependency><!-- aop --><dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId><version>1.8.9</version></dependency><!--spring websocket--><dependency><groupId>org.springframework</groupId><artifactId>spring-websocket</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-messaging</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>${spring.version}</version></dependency><!--上传文件--><dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.1</version></dependency><!-- springmvc 返回任意对象转JSON --><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-core</artifactId><version>2.8.2</version></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.8.2</version></dependency><!-- https://mvnrepository.com/artifact/c3p0/c3p0 --><dependency><groupId>c3p0</groupId><artifactId>c3p0</artifactId><version>0.9.1.2</version></dependency><!-- spring hibernate整合时需配置 --><dependency><groupId>org.springframework</groupId><artifactId>spring-orm</artifactId><version>${spring.version}</version></dependency><!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>6.0.3</version></dependency><!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 --><dependency><groupId>org.apache.commons</groupId><artifactId>commons-dbcp2</artifactId><version>2.1.1</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.12</version></dependency><!--日志打印--></dependencies><build><plugins><!-- 配置JDK编译版本 --><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><source>1.7</source><target>1.7</target></configuration></plugin></plugins></build>
</project>

web.xml:

<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN""http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app version="3.0"xmlns="http://java.sun.com/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance http://www.springmodules.org/schema/cache/springmodules-cache.xsd http://www.springmodules.org/schema/cache/springmodules-ehcache.xsd"xsi:schemaLocation="http://java.sun.com/xml/ns/javaeehttp://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><!-- 指定Spring Bean的配置文件所在目录。默认配置在WEB-INF目录下 --><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:ApplicationContext.xml</param-value></context-param><servlet><servlet-name>dispatcherServlet</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><!-- 配置 DispatcherServlet 的一个初始化参数: 配置 SpringMVC 配置文件的位置和名称 --><!--实际上也可以不通过 contextConfigLocation 来配置 SpringMVC 的配置文件, 而使用默认的.默认的配置文件为: /WEB-INF/<servlet-name>-servlet.xml--><!--  --><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:springmvc.xml</param-value></init-param><async-supported>true</async-supported><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcherServlet</servlet-name><url-pattern>/</url-pattern></servlet-mapping><welcome-file-list><welcome-file>index.jsp</welcome-file></welcome-file-list>
</web-app>

ApplicationContext.xml:

<?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:tx="http://www.springframework.org/schema/tx"xmlns:aop="http://www.springframework.org/schema/aop"xmlns:task="http://www.springframework.org/schema/task"xmlns:websocket="http://www.springframework.org/schema/websocket" xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsdhttp://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsdhttp://www.springframework.org/schema/taskhttp://www.springframework.org/schema/task/spring-task-3.0.xsdhttp://www.springframework.org/schema/websocket http://www.springframework.org/schema/websocket/spring-websocket.xsd"><!-- 配置自动扫描的包 --><context:component-scan base-package="com.sheng.example"><context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/><context:exclude-filter type="annotation" expression="org.springframework.web.bind.annotation.ControllerAdvice"/></context:component-scan><!-- 导入资源文件 --><context:property-placeholder location="classpath:db.properties"/><!-- 启动spring定时器 --><task:annotation-driven/><bean id="aspectBean" class="com.sheng.example.springaop.aspect.TestAspect" /><!-- 配置事物切点,并把切点和事物关联起来--><aop:config><aop:aspect id="TestAspect" ref="aspectBean"><!--配置com.spring.service包下所有类或接口的所有方法--><aop:pointcut id="businessService" expression="execution(* com.sheng.example.springaop.service.*.*(..))" /><aop:before pointcut-ref="businessService" method="doBefore"/><aop:after pointcut-ref="businessService" method="doAfter"/><aop:around pointcut-ref="businessService" method="doAround"/><aop:after-throwing pointcut-ref="businessService" method="doThrowing" throwing="ex"/></aop:aspect></aop:config><aop:aspectj-autoproxy></aop:aspectj-autoproxy><bean id="myInterceptor" class="com.sheng.example.springaop.aspect.TestAnnotationAspect"/>
</beans>

springmvc.xml

<?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:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"><!-- 配置自动扫描的包 --><context:component-scan base-package="com.sheng.example" use-default-filters="false"><context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/><context:include-filter type="annotation" expression="org.springframework.web.bind.annotation.ControllerAdvice"/><context:include-filter type="annotation" expression="org.springframework.web.servlet.config.annotation.EnableWebMvc"/></context:component-scan><mvc:annotation-driven  conversion-service="conversionService"></mvc:annotation-driven><!-- 支持上传文件 -->  <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  <property name="defaultEncoding" value="utf-8"></property>   <property name="maxUploadSize" value="10485760000"></property>  <property name="maxInMemorySize" value="40960"></property>  </bean><bean id="conversionService"   class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
</bean>
</beans>

log4j.properties:

# Set root logger level to error
log4j.rootLogger=INFO, Console, File###### Console appender definition ######## All outputs currently set to be a ConsoleAppender.
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%d{ABSOLUTE} %-5p [%c{3}] %m%n
#log4j.appender.Console.layout.ConversionPattern=%d{ABSOLUTE} %-5p [%c] %m%n###### File appender definition #######
log4j.appender.File=org.apache.log4j.DailyRollingFileAppender
log4j.appender.File.File=spring.log
log4j.appender.File.Append=false
log4j.appender.File.layout=org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern=%d{ABSOLUTE} %-5p [%c] %m%n

TestAspect.java 基于XML配置的切面

package com.sheng.example.springaop.aspect;import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;/*** Created by Dell on 2017/1/20.*/
public class TestAspect {public void doAfter(JoinPoint jp) {System.out.println("log Ending method: " + jp.getTarget().getClass().getName() + "." + jp.getSignature().getName());}public Object doAround(ProceedingJoinPoint pjp) throws Throwable {long time = System.currentTimeMillis();Object retVal = pjp.proceed();time = System.currentTimeMillis() - time;System.out.println("process time: " + time + " ms");return retVal;}public void doBefore(JoinPoint jp) {System.out.println("log Begining method: " + jp.getTarget().getClass().getName() + "." + jp.getSignature().getName());}public void doThrowing(JoinPoint jp, Throwable ex) {System.out.println("method " + jp.getTarget().getClass().getName() + "." + jp.getSignature().getName() + " throw exception");System.out.println(ex.getMessage());}
}

TestAnnotationAspect.java 基于注解的切面

package com.sheng.example.springaop.aspect;import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;/*** Created by Dell on 2017/1/20.*/
@Aspect
public class TestAnnotationAspect {@Pointcut("execution(* com.sheng.example.springaop.service.*.*(..))")private void pointCutMethod() {}//声明前置通知@Before("pointCutMethod()")public void doBefore() {System.out.println("前置通知");}//声明后置通知@AfterReturning(pointcut = "pointCutMethod()", returning = "result")public void doAfterReturning(String result) {System.out.println("后置通知");System.out.println("---" + result + "---");}//声明例外通知@AfterThrowing(pointcut = "pointCutMethod()", throwing = "e")public void doAfterThrowing(Exception e) {System.out.println("例外通知");System.out.println(e.getMessage());}//声明最终通知@After("pointCutMethod()")public void doAfter() {System.out.println("最终通知");}//声明环绕通知@Around("pointCutMethod()")public Object doAround(ProceedingJoinPoint pjp) throws Throwable {System.out.println("进入方法---环绕通知");Object o = pjp.proceed();System.out.println("退出方法---环绕通知");return o;}
}

AOPService.java

package com.sheng.example.springaop.service;/*** Created by Dell on 2017/1/20.*/
public interface AOPService {String aoptest();
}

AOPServiceImpl.java

package com.sheng.example.springaop.service.impl;import com.sheng.example.springaop.service.AOPService;
import org.springframework.stereotype.Service;/*** Created by Dell on 2017/1/20.*/
@Service
public class AOPServiceImpl implements AOPService {@Overridepublic String aoptest() {return "aoptest";}
}

MyController.java:

package com.sheng.example.springaop.controller;import com.sheng.example.springaop.service.AOPService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/*** Created by Dell on 2017/1/20.*/
@RestController
public class MyController {@Autowiredprivate AOPService aopService;@RequestMapping("/springaop")public String springAop(){return aopService.aoptest();}
}

启动tomcat服务,在浏览器里输入:http://localhost:8080/springaop

可以看到控制台输出:

log Begining method: com.sheng.example.springaop.service.impl.AOPServiceImpl.aoptest
进入方法---环绕通知
前置通知
后置通知
---aoptest---
最终通知
退出方法---环绕通知
process time: 0 ms
log Ending method: com.sheng.example.springaop.service.impl.AOPServiceImpl.aoptest

MyTest.java

package com.sheng.example.test;import com.sheng.example.springaop.service.AOPService;
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;/*** Created by Dell on 2017/1/20.*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations="classpath:ApplicationContext.xml")
public class MyTest {@Autowiredprivate AOPService aopService;@Testpublic void testAOP(){System.out.println(aopService.aoptest());}
}

项目下载链接: http://download.csdn.net/detail/shengfakun1234/9742116

Spring AOP实例 Junit4单元测试相关推荐

  1. Spring Aop实例之AspectJ注解配置

    上篇博文<Spring Aop实例之xml配置>中,讲解了xml配置方式,今天来说说AspectJ注解方式去配置spring aop. 依旧采用的jdk代理,接口和实现类代码请参考上篇博文 ...

  2. Spring AOP实例——异常处理和记录程序执行时间

    Spring AOP实例--异常处理和记录程序执行时间 参考文章: (1)Spring AOP实例--异常处理和记录程序执行时间 (2)https://www.cnblogs.com/victoria ...

  3. spring aop实例讲解_小实例理解Spring中的AOP----面向切面编程

    关于面向切面编程(Spring AOP),是在java面试中经常提及的,只有在充分理解了,日常工作中才能得心应手. 如何理解AOP呢?首先我们要思考为什么要使用切面编程,如下图: 对于一个系统来说保存 ...

  4. spring aop实例讲解_Spring框架核心知识点

    文章内容输出来源:拉勾教育Java高薪训练营 前言: 由于工作需要提升自身技术能力,在各方比较下,报名了拉勾教育的java高薪训练营,目前已经学了半个月啦,来说说自身学习的感受吧: 课程内容有广度更有 ...

  5. spring aop实例讲解_Spring核心技术详解(一)

    一.Sring简介 Spring是一个分层的Java SE/EE应用一站式的轻量级开源框架.Spring核心是IOC和AOP. Spring主要优点包括: 方便解耦,简化开发,通过Spring提供的I ...

  6. spring aop实例讲解_【好好面试】手把手调试,教你分析Spring-Aop

    [干货点] 此处是[好好面试]系列文的第11篇文章.看完该篇文章,你就可以了解Spring中Aop的相关使用和原理,并且能够轻松解答Aop相关的面试问题.更重要的是,很多人其实一看源码就头大,这次专门 ...

  7. Spring Aop实例之xml配置

    上篇博文<3幅图让你了解Spring AOP>中介绍了aop通知类型,AOP的配置方式有2种方式:xml配置和AspectJ注解方式.今天我们就来实践一下xml配置方式. 我采用的jdk代 ...

  8. Spring Aop实例

    在上篇博文中,我向大家介绍了Aop重要概念和教程,这回给出代码示例. 一.XML方式 1. TestAspect:切面类 [java] view plain copy package com.spri ...

  9. Java Web(5) Spring 下使用Junit4 单元测试

    2019独角兽企业重金招聘Python工程师标准>>> 1. 如何在不启动Tomcat服务器的情况下对,Dao这些不依赖使用Servlet API的类来进行单元测试呢? 其实在Spr ...

最新文章

  1. Github上的10个数据科学和机器学习知识库
  2. 【直播资料下载】Python第五讲——关于爬虫如何做js逆向的思路
  3. 算法设计与分析 2 二维递推间接递推递归分析
  4. Py中enumerate方法【转载】
  5. mysql grep 提取错误日志_详解grep获取MySQL错误日志信息的方法
  6. 如何设置Fedora默认从命令行启动?
  7. nodemanager不能正常关闭_家居燃气安全,燃气阀门的开与关可不能不当回事
  8. 抖音与六大影视公司达成合作 一年内将至少与40部影片绑定营销
  9. MFC中Socket网络通讯
  10. nohup rabbitmq python
  11. Atitit 通用接口的设计与实现attilax 总结
  12. 测试小故事82:好好说话
  13. 大神TP_萌新到大神的必修课---分路篇v
  14. 护眼的绿豆沙色 RGB 值
  15. 湘潭大学 Hurry Up 三分,求凹函数的最小值问题
  16. 安装python时无法访问筛选器,如何使用Python筛选器功能(详解)
  17. element表格默认勾选
  18. 人工智能全局概览:通用智能的当前困境和未来可能
  19. 《建筑工程定额与预算》
  20. ApkScan-PKID查壳工具+脱壳(搬运)

热门文章

  1. 1-6 JAVA [设计一个BankAccount类]
  2. 漫画汉化组,不用手动抹掉原文了:开源AI一键擦除,还能修复背景
  3. sqlite 0转换为bit_腾讯刀锋安全团队发现严重SQLite漏洞 收到谷歌苹果致谢
  4. 【1216】 青蛙(一)
  5. 最近开发的一款支持主流阅片功能的阅片器
  6. 【直播预告】CIKM 2022 论文分享:多场景个性化推荐的场景自适应自监督模型
  7. 编译原理——正规式、NFA转换构造DFA、DFA的化简
  8. 如何在python官网打不开的情况下获取获取官方最新安装包
  9. HTML学生个人网站作业设计:电影网站设计——电影从你的全世界路过(4页) HTML+CSS+JavaScript 简单DIV布局个人介绍网页模板代码 DW学生个人网站制作成品下载
  10. 国产文档控件Spire.Doc for.NET ,增强从 Word 到 PDF 和 HTML 的转换