共计 3097 个字符,预计需要花费 8 分钟才能阅读完成。
作者:小傅哥
博客:https://bugstack.cn
积淀、分享、成长,让本人和别人都能有所播种!😄
一、前言
话我放这,踩过的坑越多头发越少!
说来也是奇怪,只有是学编程的,从首次接触的 Java 到装置 JDK、IDEA、MYSQL,再到接触 Spring、MyBatis、RPC、MQ,哪怕有时候在浅的坑也会跳进去尝尝鲜,一遍抓着头发,一手点着鼠标也简直是你的常态。你的键盘里总是有很多被抓碎的头发!
但,哪怕是抓了这么头发,还是遇到了一个满脑子都是骚操作的小伙。“傅哥,我的切面怎么拦挡不到?我是照着你的《SpringBoot 中间件设计和开发》专栏写的,你给我看看吧,我都弄了一天了”
接下来我带着大家一起看看什么是高兴星球,他是怎么一顿骚操作让切面拦挡不到的!
二、满脑子都是骚操作
1. 遇到问题
上周,谢飞机 ( 化名 ) 发过来了本人的手撸的中间件源码,说这代码都没有啥怎么就不能切面呢?
- 最开始我粗心了,让谢飞机发了一些代码截图。
- 看截图的代码,这齐全就和我写的中间件里的代码一毛一样,没啥问题呀,包门路也能扫描到,咋就不能切面了?
- 我说你打个断点调试下,看看怎么切不到了呢?嘿,调试了,间接通过,就是没切面到。
- 此时我思考了 JDK 版本、环境配置、Spring 上下文、切面的定义、包的门路以及这小子是否忽悠我?
- 最初我抱着这小子忽悠我的心里,把源码要过去了。
2. 发现问题
看了几遍源码没发现问题,开始调试,还真它哈拉哨的不进这个切面,接下来;
- 谢飞机的源码保留,复制进去一份新的。
-
我的目标要先让他跑起来,在钻研。接下来我把本人的工程里的
DoJoinPoint
拷贝过去粘贴进去,噗察一下贴进去了,没提醒替换,尽管有报错但两个类能共存,如下:- 这就神奇了哈,我过后狐疑是不它那
DoJoinPoint
不是一个正经 Java 类,门路不对?有看不见的特殊字符?
- 这就神奇了哈,我过后狐疑是不它那
- 既然发现这个类不对,那行先删掉。让程序先跑起来,确保除了这个类其余的内容没有问题,这样也好排查问题。
- 还别说,去掉这个谬误类,程序能够失常运行,拦挡到切面内容了。
- 既然程序能跑了,我就想着这能够看看问题出在哪了,没想到就只关上个文件夹,就发现了一个神奇的AJ!这货压根就不是 Java 类!
3. 排查问题
要不是 IDEA 把 .aj
这货显示成 C 类的图标,可能早就发现问题了。紧接着把这谬误类的截图发给了谢飞机,问它你是怎么创立的?他说实话了
- 谢飞机先说本人偷懒了,哈哈哈,让人怪不好意思的!
- 他说在创立
DoJoinPoint
时,看到一个 Aspect 的选项,认为这个就是创立切面的快捷操作,如图; - 创立实现当前发现有点不对,不是 class 类型的,是个 aspect,于是他手动把 aspect 改成了 class,如图;
- 所以,谢飞机理论创立进去的是一个 aspect 的以
.aj
结尾的类,并不是一个正经的 Java 类,所以切面不到,也基本没有对应的 class 文件。
三、如何正确应用 Aspect 的 .aj 类
AspectJ,简称 AJ 我本人说的
AspectJ 其实也是 AOP 的一种实现技术,性能相似于拦截器,在集成在 IntelliJ IDEA 开发工具里。在应用 IntelliJ IDEA 编写 AspectJ 代码之前须要本机先装置 AspectJ 工具包。否则你的 .aj 类不能运行,同时 IDEA 类显示进去的 .aj 类,也是 C 的标识
接下来咱们就来聊聊对于这个货色怎么应用,别再被 .aj 骗了。
1. 装置 AspectJ
在应用 AspectJ 之前,须要去官网下载一个安装包,地址:https://www.eclipse.org/aspectj/downloads.php 如果官网下载的很慢,能够从我提供的源码中获取,也能够从其余路径搜寻下载 aspectj-1.9.4.jar
下载实现装置;
- 双击装置
- 命令装置
java -jar aspectj-1.9.4.jar
- 配置阐明:没有配置,傻瓜式下一步就能够了
- 默认配置装置实现当前会在 C 盘创立出一个文件夹
C:\aspectj1.9
,包含:bin、doc、lib 等,前面咱们就会应用到这些内容。
2. AspectJ 插件
在专业版 IDEA 中开发 AspectJ,须要装置以下两个插件:
- Spring AOP/@AspectJ
- AspectJ Support
3. 增加依赖 aspectjrt.jar
开始之前须要在我的项目中增加 aspectjrt.jar
依赖,aspectjrt.jar
即 AspectJ 装置目录中 lib
目录下的 jar 包。你能够复制到工程中引入,也能够间接引入
- 在工程上鼠标右键,点击 Open Module Setting 关上
Project Structure
- 点击 Libraries 选项卡,和下面的 + 号,创立 New Project Library
- 抉择 C:\aspectj1.9\lib\aspectjrt.jar 门路,点击即可配置实现
4. 配置 AspectJ 编译器
IDEA 默认应用 javac
编译器,这里须要配置 AspectJ 的编译器 ajc
,在 IDEA 中做相应配置。
- 关上 IDEA -> File -> Settings 对话
- 抉择 Build,Execution,Deployment -> Compiler -> Java Compiler
- Use complier:抉择 Ajc
- 在 Path to aspectjtools.jar 里配置门路
C:\aspectj1.9\lib\aspectjtools.jar
5. 案例测试
创立 Aspect 类
public aspect DoAspect {pointcut logPointcut():call(* ApiTest.hi(..));
void around():call(void ApiTest.hi(..)){System.out.println("call 开始...");
proceed();
System.out.println("call 完结...");
}
before(): logPointcut(){System.out.println("办法执行 before");
}
after(): logPointcut(){System.out.println("办法执行 after");
}
}
测试类
public class ApiTest {public void hi(){System.out.println("Hi Aspect");
}
public static void main(String[] args) {ApiTest apiTest = new ApiTest();
apiTest.hi();}
}
测试后果
call 开始...
办法执行 before
Hi Aspect
call 完结...
办法执行 after
Process finished with exit code 0
- 到这,才是一个对于 Aspect 类的正确打开方式,对于 Aspect 的应用也能够尝试搞搞,此篇还只是对于此类切面写法的一个入门。
四、总结
- 你的代码越粗暴、越奔放、越骚气,简直你遇到的问题也是越多的,可能就是因为没有恪守肯定的研发执行标准,所以遇到的这些有点傻的问题,简直会节约掉你一个上午或者一天。
- 但有些时候如果你能认真对待你弄出来的 bug,深入分析下它是如何产生的,并把它复现进去一点点深入研究下,可能也会失去意想不到的播种,也说不定。所以但凡认真,凡事没有好事。
- 对于切面、对于源码、对于开发,可能并不应该只重视于性能实现,甚至有时候要想方法逃离日复一日没有成长的工作内容。多在那些有价值的技术上下功夫,那你的播种也是最多的。
五、系列举荐
- 工作两三年了,整不明确架构图都画啥?
- 半年招聘筛选了 400+ 份简历,通知你怎么写容易被撩!
- 数学,离一个程序员有多近?
- 握草,你居然在代码里下毒!
- 工作两年简历写成这样,谁要你呀!