- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于注解的spring-aop日志处理
编写一个简易demo:
在maven的pom.xml文件中添加所需jar包
dependency
groupIdorg.springframework/groupId
artifactIdspring-context/artifactId
version3.0.5.RELEASE/version
/dependency
dependency
groupIdorg.aspectj/groupId
artifactIdaspectjweaver/artifactId
version1.6.11/version
/dependency
dependency
groupIdjunit/groupId
artifactIdjunit/artifactId
version4.8.2/version
scopetest/scope
/dependency
创建如下一个日志处理类
/**
* 日志记录处理类
* @author dell
*
*/
@Aspect
@Component
public class LogerAspect {
//起一个标记作用
@Pointcut(execution (* com.manager.*.service.*.*(..)))
public void logAspect(){
}
//logAspect() 引用上面的标记
@Before(value = logAspect())
public synchronized void beforeOperateLog(JoinPoint jp){
//这里可以做些调用之前的控制操作,比如说权限控制,拦截等
System.out.println(“before run….”);
}
@After(logAspect())
public synchronized void addOperateLog(JoinPoint jp){
//这里可以做一些调用之后的处理,如记录日志到数据库
System.out.println(“after run….”);
}
}
创建一个TeseService接口,以及接口的实现类TestServiceImpl
public interface TestService {
public void test();
}
public class TestServiceImpl implement TestService{
public void test(){
System.out.println(“service run….”);
}
}
在application-context.xml 配置文件中添加如下配置
!—强制使用cglib的动态代理,据说性能会好一点--
aop:aspectj-autoproxy proxy-target-class=”true”/
!—日志处理类--
bean id=myAspect class= com.manager.utils.annotation.LogerAspect/
!-- 测试service --
bean id=testService class=com.manager.system.service.TestServiceImpl/
创建一个junit单元测试
public class TestModel {
ClassPathXmlApplicationContext context;
TestService service;
@Before
public void before(){
context= new ClassPathXmlApplicationContext(application-context.xml);
service =(TestService)context.getBean(testService);
}
@Test
public void test(){
service.test();
}
}
测试运行结果显示:
模拟一个简单的增删改查的日志记录过程
首先创建一个描述注解,用与对字段进行描述,后期用得到
/**
* 注解字段
* @author dell
*
*/
@Target(ElementType.FIELD) //表示该注解只能用于字段
@Retention (RetentionPolicy.RUNTIME)
@Document
您可能关注的文档
最近下载
- 《3D打印技术概论》电子教案.pdf VIP
- 水平一(一、二年级)《体育与健康》全册教案.pdf VIP
- DB22T 162-2017建筑消防设施检验规程.docx
- 中国肿瘤整合诊疗指南(2025版)结直肠癌及肛管癌更新要点解读.pptx VIP
- 第11课 依法从事民事活动 教案 中职高教版 职业道德与法治.pdf
- 03婴幼儿练习试题附答案(一).docx VIP
- 《救救我小猫》超清有声动态PPT课件.pptx VIP
- 全国党员管理信息采集表及采集标准.pdf VIP
- 山山水水(教学设计)人美版2025美术一年级下册 .pdf VIP
- 工学一体化课程《小型网络管理与维护》任务2单元2教学单元活动方案.docx VIP
文档评论(0)