日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

AOP切入同类调用方法不起作用,AopContext.currentProxy()帮你解决这个坑

發布時間:2023/12/10 编程问答 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 AOP切入同类调用方法不起作用,AopContext.currentProxy()帮你解决这个坑 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原來在springAOP的用法中,只有代理的類才會被切入,我們在controller層調用service的方法的時候,是可以被切入的,但是如果我們在service層 A方法中,調用B方法,切點切的是B方法,那么這時候是不會切入的,解決辦法就是如上所示,在A方法中使用((Service)AopContext.currentProxy()).B() 來調用B方法,這樣一來,就能切入了!

Spring的切面功能,是通過代理的方式來實現的,實現方式有JDK動態代理方式及Cglib的方式。

有時需要在service層通過AOP做一些日志、權限、監控等功能,但在service中進行自調用時,無法再次走進代理類中,因此會導致漏日志的情況出現。

此時,可通過AopContext.currentProxy()來解決問題。用AopContext.currentProxy().xxxx()的方式代替this.xxxx()的自調用方式。
AopContext.currentProxy()的本質是使用的ThreadLocal生成本地代理,這樣的做法可能影響性能,后續文章對ThreadLocal的內部原理和性能進行進一步深入!


AopContext.currentProxy()該用法的意義

下面講用一個例子講解

首先加入依賴

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId><scope>test</scope></dependency><dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId></dependency>

?

?

?

在啟動類上加上如下注解

@SpringBootApplication @Configuration//@EnableAsync @EnableAspectJAutoProxy(exposeProxy = true)//開啟spring注解aop配置的支持

?

新增一個實體類User

public class User implements Serializable {private String id;private String username;private String password;private String email;private Date birthday;private String gender;private String mobile;private String nickname;public String getId() {return id;}public void setId(String id) {this.id = id;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public String getEmail() {return email;}public void setEmail(String email) {this.email = email;}public Date getBirthday() {return birthday;}public void setBirthday(Date birthday) {this.birthday = birthday;}public String getGender() {return gender;}public void setGender(String gender) {this.gender = gender;}public String getMobile() {return mobile;}public void setMobile(String mobile) {this.mobile = mobile;}public String getNickname() {return nickname;}public void setNickname(String nickname) {this.nickname = nickname;}}

?

?

新增UserService接口

public interface UserService {/*** 模擬保存用戶* @param user*/void saveUser(User user);/*** 批量保存用戶* @param users*/void saveAllUser(List<User> users); }

?

新增一個切面類

@Component @Aspect//表明當前類是一個切面類 public class LogUtil {/*** 用于配置當前方法是一個前置通知*/@Before("execution(* com.example.demo1.demo.test3.*.saveUser(..))")public void printLog() {System.out.println("執行打印日志的功能");} }

?

?

?

新增UserServiceImpl實現類

@Service("userService") public class UserServiceImpl implements UserService{@Overridepublic void saveUser(User user) {System.out.println("執行了保存用戶"+user);}@Overridepublic void saveAllUser(List<User> users) {for(User user : users){ // UserService proxyUserServiceImpl = (UserService) AopContext.currentProxy(); // proxyUserServiceImpl.saveUser(user);saveUser(user);}} }

?

新增測試類SpringEnableAspecctJAutoProxyTest

public class SpringEnableAspecctJAutoProxyTest {public static void main(String[] args) {//1.創建容器AnnotationConfigApplicationContext ac = new AnnotationConfigApplicationContext(DemoApplication.class);//2.獲取對象UserService userService = ac.getBean("userService",UserService.class);//3.執行方法User user = new User();user.setId("1");user.setUsername("test");List<User> users = new ArrayList<>();users.add(user);userService.saveAllUser(users);} }

?

啟動測試類

輸出

執行了保存用戶com.example.demo1.demo.test3.User@5db99216

?

把注釋的這兩行代碼放開,然后運行代碼 UserService proxyUserServiceImpl = (UserService) AopContext.currentProxy(); proxyUserServiceImpl.saveUser(user);

?

?

可以看到加上

UserService proxyUserServiceImpl = (UserService) AopContext.currentProxy(); proxyUserServiceImpl.saveUser(user);代碼后輸出了切面類中的

執行打印日志的功能語句

總結

以上是生活随笔為你收集整理的AOP切入同类调用方法不起作用,AopContext.currentProxy()帮你解决这个坑的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。