目录

  • 一、前言

  • 二、满脑子都是骚操作

    • 1. 遇到问题

    • 2. 发现问题

    • 3. 排查问题

  • 三、如何正确使用 Aspect 的 .aj 类

    • 1. 安装 AspectJ

    • 2. AspectJ 插件

    • 3. 添加依赖 aspectjrt.jar

    • 4. 配置AspectJ编译器

    • 5. 案例测试

  • 四、总结

  • 五、系列推荐

一、前言

话我放这,踩过的坑越多头发越少!

说来也是奇怪,只要是学编程的,从初次接触的 Java 到安装 JDK、IDEA、MYSQL, 再到接触 Spring、MyBatis、RPC、MQ,哪怕有时候在浅的坑也会跳进去尝尝鲜,一遍抓着头发,一手点着鼠标也几乎是你的常态。你的键盘里总是有很多被抓碎的头发!

接下来我带着大家一起看看什么是快乐星球,他是怎么一顿骚操作让切面拦截不到的!

二、满脑子都是骚操作

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包。你可以复制到工程中引入,也可以直接引入

  1. 在工程上鼠标右键,点击 Open Module Setting 打开 Project Structure

  2. 点击 Libraries 选项卡,和上面的 + 号,创建 New Project Library

  3. 选择 C:\aspectj1.9\lib\aspectjrt.jar 路径,点击即可配置完成

4. 配置AspectJ编译器

IDEA 默认使用 javac 编译器,这里需要配置 AspectJ 的编译器 ajc,在 IDEA 中做相应配置。

  1. 打开 IDEA -> File  -> Settings 对话

  2. 选择 Build,Execution,Deployment -> Compiler -> Java Compiler

  3. Use complier:选择 Ajc

  4. 在 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 结束...
方法执行 afterProcess finished with exit code 0
  • 到这,才是一个关于 Aspect 类的正确打开方式,关于 Aspect 的使用也可以尝试搞搞,此篇还只是关于此类切面写法的一个入门。

四、总结

  • 你的代码越粗犷、越豪放、越骚气,几乎你遇到的问题也是越多的,可能就是因为没有遵守一定的研发执行规范,所以遇到的这些有点傻的问题,几乎会浪费掉你一个上午或者一天。

  • 但有些时候如果你能认真对待你弄出来的bug,深入分析下它是如何产生的,并把它复现出来一点点深入研究下,可能也会得到意想不到的收获,也说不定。所以凡是认真,凡事没有坏事。

  • 关于切面、关于源码、关于开发,可能并不应该只注重于功能实现,甚至有时候要想办法逃离日复一日没有成长的工作内容。多在那些有价值的技术上下功夫,那你的收获也是最多的。

一个Bug,让我发现了Java界的.AJ(锥)!相关推荐

  1. 给 JDK 官方提了一个 Bug,结果...

    图 by:石头@北京-望京 关于作者:程序猿石头(ID: tangleithu),现任阿里巴巴技术专家,清华学渣,前大疆后端 Leader. 背景 分享一下之前踩的一个坑,背景是这样的: 我们的项目依 ...

  2. 软件测试培训分享:做软件测试工作如何清楚的描述一个bug

    一名合格的软件测试工程师是需要清楚的交代自己的工作任务的,必须要清楚的告诉技术员出现的bug,那么做软件测试工作如何清楚的描述一个bug呢?来看看下面的详细介绍. 软件测试培训分享:做软件测试工作如何 ...

  3. 什么是bug?如何描述一个bug?

    什么是bug? bug就是软件缺陷,软件错误 当产品规格说明是正确的,但是程序与产品规格说明之间的不匹配就是bug. 当程序没有实现其最终用户合理预期的功能要求时,就是bug. 通俗来说: 产品说明书 ...

  4. 37 岁学编程,发现第一个 Bug,创造商业编程语言 | 人物志

    Humans are allergic to change. They love to say, "We've always done it this way." I try to ...

  5. 几年前的代码发现一个BUG: 整数相除结果不能默认转换为浮点数

    2019独角兽企业重金招聘Python工程师标准>>> 几年前的代码发现一个BUG: #include "stdafx.h" #include "std ...

  6. 和vs版本关系_栈局部变量优化探究,意外发现了 vs 的一个 bug ?

    缘起 我在<栈又溢出了>一文中记录了一个奇怪的栈溢出问题.虽然解决了,但是总感觉哪里不太合理.我想,vs 一定有一个合理的设置.一起折腾起来吧! 查找工程设置 本以为能找到某个编译选项对局 ...

  7. 1 为发现 php,magento 1.8.1中发现sitemap模块的一个bug

    magento的sitemap模块是magento给商品分类和商品构建一个类似地图索引的功能,一来是为了方便用户定位到商品,更直接的目的应该是服务于SEO.不过我在magento 1.8.1版本中使用 ...

  8. AI溃败,被Dota2职业战队打蠢!独家专访OpenAI:我们发现一个Bug

    中奇 夏乙 一璞 假装发自 温哥华 新浪科技&量子位 联合报道 整整鏖战52分钟. 今天早间进行的Ti8 OpenAI表演赛上,人类职业战队paiN Gaming,在5v5的Dota2人机大战 ...

  9. 记录一个bug 关于 java 解压缩包 写入本地报错 :java.io.FileNotFoundException(系统找不到指定的路径。)

    记录一个bug 关于 java 解压缩包 写入本地报错 :java.io.FileNotFoundException(系统找不到指定的路径.) 第一想法是路径问题: 1.检查文件路径是否正确 2.另外 ...

最新文章

  1. 结合案例深入解析策略模式
  2. C、C++中的转义符
  3. 栈(顺序存储)C++模板实现
  4. 前端学习(1666):前端系列实战课程之仿造qq发送消息思路
  5. php删除字段某个字段,php数如何组删除某个字段
  6. C语言 指针和数组区别 - C语言零基础入门教程
  7. overflow encountered in ubyte_scalars像素加减运算溢出异常
  8. python从指定文件夹导入模块_Python实现的在特定目录下导入模块功能分析
  9. gdpr合规性测试_使用生产数据在GDPR后世界进行测试
  10. 从无到有axure原型设计_Axure|微信原型制作
  11. 遗传算法是机器学习算法嘛?_基于遗传算法的机器人控制器方法
  12. matlab安装自行下载的工具箱
  13. rpm的安装与卸载,常用命令记载
  14. Activiti工作流的流转任务和结束任务
  15. 本人累计多年整理的所有软件 需要请留言 适合毕业设计参考
  16. vue树形权限菜单_vue树形菜单
  17. 【愚人节小程序】Java Swing的简单使用
  18. win10兼容模式怎么设置_Win10游戏模式,你真的会用吗?只有这样设置,游戏操作才流畅...
  19. 手动部署OpenStack之环境部署
  20. 制作excle报盘模板

热门文章

  1. ds图—最小生成树_Java: Kruskal算法生成最小生成树(邻接矩阵)
  2. js remove 当前元素_D3.js入门教程
  3. XML DOM – 导航节点概述
  4. 从命令行使用 wget 调试网页错误
  5. java 时间加减_Java中时间加减的比较
  6. hive to mysql_Hive And MySQL安装及设置
  7. HDU5934(强连通分量)
  8. 期望dp ---- B. Tree Array 思维+期望dp 逆序对期望数
  9. 树上启发式合并问题 ---- D. Tree Requests [状态压缩+树上启发式合并]
  10. 树和二叉树(四种遍历,建树)详解+二叉排序树(包含图像和相关习题)