文档章节

你的注解(@Transactional,@Aspect)失效了吗?

wpfc
 wpfc
发布于 2017/06/04 13:41
字数 553
阅读 66
收藏 1
点赞 0
评论 0

今天想通过AOP的方式定义一个切面进行日志管理,稍微描述一下

记录日志的类

@Component
@Aspect
public class MyLog {

	@Around("execution(* cn.edu.ntu.controller.*.*(..)) && @annotation(cn.edu.ntu.interfaces.Log)")
	public Object around(ProceedingJoinPoint point){
		Object result = null;
		try {
			long start = System.currentTimeMillis();
			result = point.proceed();
			System.out.format("打印日志");
		} catch (Throwable e) {
			e.printStackTrace();
		}
		return result;
	}
}

控制层需要添加日志的方法

@Controller
@RequestMapping("/user")
public class UserController extends BaseController {

	@Autowired
	private UserService userService;
	
	@RequestMapping("/queryUserList")
	@Log(module="用户管理", operation="用户列表查询")
	public String queryUserList(Model model){
		User user = null;
		user = (User) memcacheClient.get("user");
		if(user == null){
			System.out.println("===从数据库获取数据。。。===");
			user = userService.queryUserById(1L);
			memcacheClient.set("user", 60000, user);
		}
		System.out.println("userid : " + user.getUserId() + "userName : "+user.getUserName());
		model.addAttribute("user", user);
		return "/userList";
	}
	
	@RequestMapping("/insertUser")
	public void insertUser(){
		userService.insertUser(new User("wpfc"));
	}
	
}

自定义日志注解

@Target({ElementType.PARAMETER, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Log {
	
	/**
	 * 模块名称
	 */
	public String module() default "";   
    
	/**
	 * 操作说明
	 */
    public String operation() default "";

}

自动为spring容器中那些配置@aspectJ切面的bean创建代理,织入切面。

<aop:aspectj-autoproxy proxy-target-class="true"/>

但是一直无法实现功能,看了这边文章才恍然大悟 Spring aop @aspect无法执行切入方法

于是将aop切面配置(<aop:aspectj-autoproxy proxy-target-class="true"/>)从spring的配置文件挪到了springmvc的配置文件中, 这下才解决了问题。

最重要的一点在于(22楼的观点:如果要是切面切在Service层或是Dao层, 那么<aop:aspectj-autoproxy proxy-target-class="true"/>放在application.xml也是可以,主要看你的切面切在了controller层还是controller以后的层

这才让我恍然大悟: 我在配置文件中让springmvc专门管理Controller层,而spring去管理其他的 (springmvc是处理映射请求,而spring是bean容器)

/*springmvc的配置*/
<!-- 扫描controller springmvc只扫描controller-->
    <context:component-scan base-package="cn.edu.ntu">
	    <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />  
		<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />  
    </context:component-scan>

/*spring的配置*/
<!-- springmvc controller加上事务无效   http://blog.csdn.net/u011580177/article/details/46840033 
    	 Controller层只支持 @Transactional 注解式事务!
    	 springmvc.xml只扫描Controller
    -->
    <context:component-scan base-package="cn.edu.ntu" annotation-config="true">  
      <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />   
 	</context:component-scan> 

我的日志记录是放在Controller层,属于springmvc管理的子容器中,而aspect处在 spring管理的父容器中,因此找不到子容器中的元素,导致日志记录不生效(事务不生效童同样的道理)。

输入图片说明

参考:

Spring 和SpringMVC 的父子容器关系

spring与springmvc的关系

© 著作权归作者所有

共有 人打赏支持
wpfc
粉丝 5
博文 21
码字总数 5298
作品 0
南京
程序员
@transactional 使用注意事宜

在需要事务管理的地方加@Transactional 注解。@Transactional 注解可以被应用于接口定义和接口方法、类定义和类的 public 方法上。 2. @Transactional 注解只能应用到 public 可见度的方法上...

紫萱格主 ⋅ 2015/05/12 ⋅ 0

Spring注解@Async和@Transactional失效问题究竟是什么原因,强势解释一波

原文作者:弥诺R 原文地址:http://www.minuor.com/1524750647/article 转载声明:转载请注明原文地址,注意版权维护,谢谢! 提前说说 项目中涉及到的代码我都会上传到码云(gitee)或者githu...

兴趣e族 ⋅ 04/28 ⋅ 0

spring4 --jar包简介

如下列举我在工程中常用的spring jar包,没有列出的,以后用到了逐步列出来 1.spring-core:它包含spring框架的基本核心工具类,spring其它jar包都要使用到这个jar包里面的类。例如:asm、c...

求是科技 ⋅ 2016/08/09 ⋅ 0

@Transaction必知必会

1. Spring事务的基本原理 事务管理是应用系统开发中必不可少的一部分。Spring 为事务管理提供了丰富的功能支持。Spring 事务管理分为编码式和声明式的两种方式。编程式事务指的是通过编码方式...

maskwang520 ⋅ 04/15 ⋅ 0

atomikos在Tomcat中无法正确执行

请教一个关于分布式事务的问题,项目中使用到了多数据源,导致普通的事务无效,在网上找到了atomikos可以帮助Tomcat完成多数据源事务,但是配置完成后我在junit测试中可以正确执行回滚,但是...

Lindp ⋅ 2015/06/17 ⋅ 0

Srping @Transactional 一

@Transactional 注解应该只被应用到 public 可见度的方法上。 如果你在 protected、private 或者 package-visible 的方法上使用 @Transactional 注解,它也不会报错, 但是这个被注解的方法将...

pczhangtl ⋅ 2013/12/09 ⋅ 0

Spring 事务

Spring 使用注解方式进行事务管理 使用步骤: 步骤一、在spring配置文件中引入tx:命名空间 步骤二、具有@Transactional 注解的bean自动配置为声明式事务支持 <!-- 事务管理器配置, Hibernate...

Q317075064 ⋅ 2016/09/29 ⋅ 0

spring service作日志切面后,事务竟然会失效?

在servvice层的某个方法用@transactional开启事务, 也在service的方法用自定义注解开启日志切面, 结果,service层报异常,事务不回滚。 去除方法上的日志切面注解,事务又生效了....... 这...

KerryLi ⋅ 2017/08/24 ⋅ 6

spring的事物配置

概念说完了,下面是说说怎么实际操作。 首先是spring配置文件: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://......

尚浩宇 ⋅ 2015/06/24 ⋅ 0

Springboot @Async 异步方法

Springboot @Async 异步方法 1.异步调用 异步调用就是在不阻塞主线程的情况下执行高耗时方法 2.常规异步 通过开启新线程实现 3.在Springboot中启用异步方法 需要4个注解 @EnableAsync 开启异...

qq_15071263 ⋅ 05/02 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

NFS介绍 NFS服务端安装配置 NFS配置选项

NFS介绍 NFS是Network File System的缩写;这个文件系统是基于网路层面,通过网络层面实现数据同步 NFS最早由Sun公司开发,分2,3,4三个版本,2和3由Sun起草开发,4.0开始Netapp公司参与并主导...

lyy549745 ⋅ 9分钟前 ⋅ 0

Spring AOP 源码分析 - 筛选合适的通知器

1.简介 从本篇文章开始,我将会对 Spring AOP 部分的源码进行分析。本文是 Spring AOP 源码分析系列文章的第二篇,本文主要分析 Spring AOP 是如何为目标 bean 筛选出合适的通知器(Advisor...

java高级架构牛人 ⋅ 32分钟前 ⋅ 0

HTML-标签手册

标签 描述 <!--...--> 定义注释。 <!DOCTYPE> 定义文档类型。 <a> 定义锚。超链接 <abbr> 定义缩写。 <acronym> 定义只取首字母的缩写。 <address> 定义文档作者或拥有者的联系信息。 <apple......

ZHAO_JH ⋅ 34分钟前 ⋅ 0

SylixOS在t_main中使用硬浮点方法

问题描述 在某些使用场景中,应用程序不使用动态加载的方式执行,而是跟随BSP在 t_main 线程中启动,此时应用代码是跟随 BSP 进行编译的。由于 BSP 默认使用软浮点,所以会导致应用代码中的浮...

zhywxyy ⋅ 41分钟前 ⋅ 0

JsBridge原理分析

看了这个Github代码 https://github.com/lzyzsd/JsBridge,想起N年前比较火的Hybrid方案,想看看现在跨平台调用实现有什么新的实现方式。代码看下来之后发现确实有点独特之处,这里先把核心的...

Kingguary ⋅ 53分钟前 ⋅ 0

Intellij IDEA神器常用技巧五-真正常用快捷键(收藏级)

如果你觉得前面几篇博文太啰嗦,下面是博主多年使用Intellij IDEA真正常用快捷键,建议收藏!!! sout,System.out.println()快捷键 fori,for循环快捷键 psvm,main方法快捷键 Alt+Home,导...

Mkeeper ⋅ 53分钟前 ⋅ 0

Java 静态代码分析工具简要分析与使用

本文首先介绍了静态代码分析的基本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代码分析工具 (Checkstyle,FindBugs,PMD,Jtest),最后从功能、特性等方面对它们进行分析和比较,...

Oo若离oO ⋅ 55分钟前 ⋅ 0

SpringBoot自动配置小记

spring-boot项目的特色就在于它的自动配置,自动配置就是开箱即用的本源。 不过支持一个子项目的自动配置,往往比较复杂,无论是sping自己的项目,还是第三方的,都是如此。刚接触会有点乱乱...

大_于 ⋅ 今天 ⋅ 0

React jsx 中写更优雅、直观的条件运算符

在这篇文字中我学到了很多知识,同时结合工作中的一些经验也在思考一些东西。比如条件运算符 Conditional Operator condition ? expr_if_true : expr_if_false 在jsx中书写条件语句我们经常都...

开源中国最帅没有之一 ⋅ 今天 ⋅ 0

vim编辑模式与命令模式

5.5 进入编辑模式 从编辑模式返回一般模式“Esc” 5.6 vim命令模式 命令 :“nohl”=no high light 无高亮,取消内容中高亮标记 "x":保存退出,和wq的区别是,当进入一个文件未进行编辑时,使...

弓正 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部