aop的实现原理_非Spring管理Bean如何添加AOP呢?

前几天有个朋友问了一个问题,觉得可以给大家分享一下。

问题如下图

b5e3b696d0b292f366451b54dd7d4e74.png

归其根本这是个历史项目,里面有很多的类并没有交给spring管理,但现在需要统一添加日志。

面对这样的问题,其实只要了解AOP的原理,就会有多种方法。AOP都是基于动态代理来实现,而动态代理常见的就是cglib和java动态代理,不了解的可以看下之前干货君写的文章

java动态代理为什么需要基于接口

cglib动态代理对类没有任何限制吗?

但此两种方法似乎在这样的场景不好实现,需要修改大量的代码,那么有没有什么好的方案呢?

答案当然是有。

首先要清楚的是AOP的底层实现原理就是字节码,我们只需要从字节码层面,就一定可以解决这样的问题。因此可以利用编译期增强和运行期增强,常见的方案有两种,一种Java Agent技术,另一种 AspectJ方案。

Java Agent

Java Agent中文名字叫做java 探针,可以在运行java时指定探针程序,对原程序无侵入,常见的一些APM工具都会这样,如skywalking,后续有机会给大家介绍下。如下图

37c23d8140f96a8b3dfa56ae3d1fe648.png

java agent的主要原理就是利用JVMTI(JVM Tool Interface),JVM用来暴露一些供用户扩展的接口集合,因此可以在此处做一些运行期字节码增强。

Java Agent内容比较多,有很多大家熟悉的工具都是基于它去做的,例如阿里的arthas。本文就不介绍了,后期会给大家详细介绍下Java Agent。

AspectJ方案

可以利用aspectj + javac来编译织入代码,也可以利用maven插件aspectj-maven-plugin,下面利用AspectJ注解 + aspectj-maven-plugin来实战一下。

aspectj-maven-plugin官网 http://www.mojohaus.org/aspectj-maven-plugin/usage.html

引入依赖

编译增强,依赖此jar

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Before;

import org.aspectj.lang.annotation.Pointcut;

@Aspect

public class Aop {

@Pointcut("execution(* com.ganhuojun.gracefulshutdown.controller..*.*(..))")

public void pointcut1(){

}

@Before("pointcut1()")

public void before(){

System.out.println("controller before");

}

}

定义注解

注意:该注解不要交给spring管理

org.codehaus.mojo

aspectj-maven-plugin

1.11

1.8

1.8

UTF-8

src/main/java

**/ServiceAop.java

compile

配置maven插件

org.codehaus.mojo

aspectj-maven-plugin

1.11

1.8

1.8

UTF-8

src/main/java

**/ServiceAop.java

compile

排除spring的aop

如果对spring aop比较熟悉的都知道,spring的aop也是基于AspectJ的,因此需要exclude的,已经配置到mavn的地方了。

编译&运行&测试

编译后class文件已经被织入了相关代码,如下图

70f6af8f696eead36e3ac74fdcd2237b.png

运行相关日志输出如下

f2ea07516f0d2898b04714fc3f6e0119.png

说明功能已经实现。

如果还有其他比较好的方法,欢迎大家留言,谢谢

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/550693.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

什么从什么写短句_2020抖音文案短句:爱情、励志、伤感合集,值得收藏!

视频火不火,一半看文案!想知道爆款视频的文案都是什么吗?想知道爆款文案的套路吗?今天,我就给大家整理了近期抖音爆款短视频的文案——爱情、励志、伤感短句,句句深入人心,赶紧来看看吧&#xf…

插入数据的时候出现错误:Error during job, obtaining debugging information…

插入数据的时候出现错误:Error during job, obtaining debugging information… 原因: Javaf堆内存不足 解决办法 修改为本地模式 set hive.exec.mode.local.autotrue;

win10更新失败,怎么删除临时文件下面的更新

首先按下WINR,然后在运行中输入services.msc 回车在服务中找到Windows update服务,右键点击停止然后打开文件夹C:\Windows\SoftwareDistribution\DownloadSoftwareDistribution\Download文件夹下就是更新后留下来的更新文件了,全部删除吧删除…

::在sql语句中是什么写法_不懂就问:SQL 语句中 where 条件后 写上1=1 是什么意思...

程序员在编程过程中,经常会在代码中使用到“where 11”,这是为什么呢?SQL注入初次看到这种写法的同学肯定很纳闷,加不加where 11,查询不都一样吗?例如:select * from customers; 与 select * fr…

U盘:对于目标文件系统,文件过大放不到u盘里

问题描述:从电脑复制粘贴一个11G的压缩包时,提示"对于目标文件系统,文件过大放不到u盘里" 原因:U盘的文件格式为FAT32,转为NTFS格式才支持大文件复制。 解决方法: 格式化为NTFS格式 U盘卷符名为…

django 集成个推_持续集成CircleCI vs Travis CI vs Jenkins

Continuous Integration. CircleCI vs Travis CI vs Jenkins​hackernoon.com持续集成(CI)的定义及其主要目标持续集成(CI)是一种软件开发实践,它基于将代码频繁集成到共享代码仓中。 然后通过自动构建(automated build)验证每个签入(Check-In)。持续集成(CI)的主要…

org.apache.hadoop.security.AccessControlException: Permission denied: user=anonymous, access=EXECUTE

直接在hdfs文件系统上修改supergroup的权限,解决问题 [roothadoop001 hadoop-3.1.3]# hdfs dfs -chmod -R 777 /tmp

战双帕弥什自抽号怎么使用_战双帕弥什新S冰露怎么玩《战双帕弥什》新S冰露玩法技巧...

战双帕弥什新S冰露怎么玩呢,新的S构造体更新之后正式登场,不少玩家都对他不太了解,接下来就让小编给大家带来《战双帕弥什》新S冰露玩法技巧介绍。《战双帕弥什》新S冰露玩法技巧介绍 冰露技能分为两种形式,一种是极寒形态&#x…

log4j:WARN No appenders could be found for logger (org.apache.ibatis.logging.LogFactory). log4j:WARN

1. 警告信息 log4j:WARN No appenders could be found for logger (org.apache.ibatis.logging.LogFactory). log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info. 2. 解决方法 在…

ppt讲解中的过渡_PPT黑科技,只用一张图做出3D动画

我一直在探索PPT中平滑切换的应用。这篇文章感觉算是探索到头了。之前的文章中,曾经提到过平滑切换可以让3D模型动起来。但是在实际应用中,能够供PPT使用的3D素材数量有限,难以准确契合我们的需求。后来我发现,只需要1张普通图片&…

HDFS常用端口

HDFS常用端口 HDFS 参数描述默认配置文件例子fs.default.name namenodenamenode RPC交互端口8020core-site.xmlhdfs://master:8020/dfs.http.addressnamenode web管理端口50070hdfs-site.xml0.0.0.0:50070dfs.datanode.addressdatanode控制端口50010hdfs-site.xml0.0.0.0:500…

的好处_女性做下蹲运动有什么好处 原来有这些好处

我们在小时候如果犯了错,那么很可能会被老师或者家长罚着做下蹲。因为下蹲非常的累,其实下蹲累的原因就是它的锻炼效果非常的明显。那么你知道女人做下蹲运动的好处是什么呢?下面我们一起去健身知识那里看看吧!女人做下蹲运动的好…

阿里云使用idea通过hdfs api来上传文件时出现could only be written to 0 of the 1 minReplication nodes.错误

问题描述: 使用阿里云服务器,在本地windows电脑上使用idea进行hdfs api操作来上传文件时出现错误如下: org.apache.hadoop.ipc.RemoteException(java.io.IOException): File /a.xlsx could only be written to 0 of the 1 minReplication nod…

birt什么意思中文翻译_ECTN是什么意思

ECTN是什么意思?ECTN是英语ELECTRONIC CARGO TRACKING NOTE的简称,中文翻译为电子货物跟踪单。从9月1日起,贝宁ECTN号码必须显示在提单上,根据BENIN贝宁法令,所有发货至贝宁科托努(COTONOU)港或经由此港转往尼日尔、布…

cmd在执行hadoop version时出现系统找不到指定的路径。 Error: JAVA_HOME is incorrectly set

问题描述 系统找不到指定的路径。 Error: JAVA_HOME is incorrectly set. Please update C:\Program_Files\hadoop\hadoop-3.1.3\etc\hadoop\hadoop-env.cmd ‘-Xmx512m’ 不是内部或外部命令,也不是可运行的程序 原因 我的JAVA_HOME路径是"C:\Program Files\J…

dockerfile如何运行镜像内的脚本_第七章 Dockerfile文件解析(一)

七 Dockerfile文件解析-17.1 定义:Dockerfile是用来构建Docker镜像的文件,是由一系列命令和参数构成的脚本7.2 Dockerfile内容基础知识:1.每条保留字指令字母必须为大写,并且后面必须跟随参数2.指令从上到下,依次执行3.#为注释内容4.每条指令都会创建一个新的镜像层,并对镜像层…

dfs.client.block.write.replace-datanode-on-failure

问题描述 在使用hdfs api追加内容操作,从windows电脑上的idea对aliyun服务器上的hdfs中的文件追加内容时,出现错误,如下: java.io.IOException: Failed to replace a bad datanode on the existing pipeline due to no more good …

hdfs中Exception in createBlockOutputStream以及MapReduce中I/O error constructing remote block reader

问题描述 (1) windows电脑向aliyun进行hdfs api文件追加操作时出现下方错误: DEBUG [Thread-3] (DFSOutputStream.java:1503) - Connecting to datanode *.*.*.*:9866 DEBUG [IPC Client (927327686) connection to centos8/*.*.*.*:9820 from root] (Client.java:1…

开机显示输入最佳预设值_开机黑屏,有招了(收藏篇)

我的本本有时候就和女朋友一样昨天还好好的,今天就生气了真的啥也没干, 到底因为啥呢?真的想不起来你都干了啥?当然小编想着黑屏问题好像也同样困扰着小伙伴们;所以下次电脑再黑屏,先不要冲动,小…

MapReduce操作时Error:The method setInputPaths(JobConf, String) in the type FileInputFormat is not

问题描述 今天在写java API的MapReduce操作时,出现了Error:The method setInputPaths(JobConf, String) in the type FileInputFormat is not的错误 错误原因 导错了包,JobConf是旧API使用的。导入的错误的包是org.apache.hadoop.mapred.Fil…