本文转载自微信公众号「bugstack虫洞栈」,作者小傅哥 。转载本文请联系bugstack虫洞栈公众号。
成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于网站制作、成都网站建设、海南州网络推广、小程序定制开发、海南州网络营销、海南州企业策划、海南州品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供海南州建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com
目录
一、前言
话我放这,踩过的坑越多头发越少!
说来也是奇怪,只要是学编程的,从初次接触的 Java 到安装 JDK、IDEA、MYSQL, 再到接触 Spring、MyBatis、RPC、MQ,哪怕有时候在浅的坑也会跳进去尝尝鲜,一遍抓着头发,一手点着鼠标也几乎是你的常态。你的键盘里总是有很多被抓碎的头发!
但,哪怕是抓了这么头发,还是遇到了一个满脑子都是骚操作的小伙。傅哥,我的切面怎么拦截不到?我是照着你的《SpringBoot 中间件设计和开发》专栏写的,你给我看看吧,我都弄了一天了
接下来我带着大家一起看看什么是快乐星球,他是怎么一顿骚操作让切面拦截不到的!
二、满脑子都是骚操作
1. 遇到问题
上周,谢飞机(化名)发过来了自己的手撸的中间件源码,说这代码都没有啥怎么就不能切面呢?
2. 发现问题
看了几遍源码没发现问题,开始调试,还真它哈拉哨的不进这个切面,接下来;
3. 排查问题
要不是IDEA把 .aj 这货显示成 C 类的图标,可能早就发现问题了。紧接着把这错误类的截图发给了谢飞机,问它你是怎么创建的?他说实话了
三、如何正确使用 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
下载完成安装;
默认配置安装完成以后会在C盘创建出一个文件夹 C:\aspectj1.9,包括:bin、doc、lib等,后面我们就会使用到这些内容。
2. AspectJ 插件
在专业版 IDEA 中开发 AspectJ,需要安装以下两个插件:
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 中做相应配置。
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,深入分析下它是如何产生的,并把它复现出来一点点深入研究下,可能也会得到意想不到的收获,也说不定。所以凡是认真,凡事没有坏事。
关于切面、关于源码、关于开发,可能并不应该只注重于功能实现,甚至有时候要想办法逃离日复一日没有成长的工作内容。多在那些有价值的技术上下功夫,那你的收获也是最多的。
文章名称:一个Bug,让我发现了Java界的.AJ(锥)!
文章网址:http://www.mswzjz.cn/qtweb/news25/405625.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能