全网最详细IDE插件开发之代码审计

访客4年前关于黑客接单1167

一、背景

代码审计,想必搞安全的同学再熟悉不过了,和标题中的IDE 插件有什么关系呢?莫不是标题党?
偶然挖洞闲暇时,发现了陌陌安全SRC的一个公告SAST开源,赶紧去撸一波源码,最终以看不懂为由挂机了。因此我决定从IDE插件开发学起,撸光它的码子。安全行业难能可贵的是开源精神,谢谢大厂。有请今天的主角momo-code-sec-inspector-java。大家可以先看着源码,看不懂了我们在来看看我下面的从0到1学开发插件。

二、开发环境搭建

像我这种小白,一般官方文档都是先不看,百度、bing、google一遍,看看有没有大神的教程系列,到最后基本上没有一个很全的文章。要么时间比较老,要么照着搭环境却起不来。后面我将带着大家一步一步的来,保证你能突破开发环境的这一步,并且弄懂momo安全开源SAST规则,让自己的代审功力提升。

2.1准备工作

序号软件名备注
1idea 2020.1.4 community下载页面
2JDK百度云链接密码:9k19
3momo 开源代码git clone地址

2.2 JDK安装

下一步大法,我就不详细截图了

2.3 IDEA安装配置

安装也是下一步到底就OK了

1. 新建项目
选择gradle创建项目,gradle创建项目便于插件开发依赖管理,关键它支持intellij platform plugin
如果JDK你安装没问题,这里的project SDK会自动选择1.8
image.png

2. 填好项目名,点击finish

image.png

3. 等待gradle创建项目框架
此时它在下载需要的IDEA的源码沙箱,以便于我们调试时,启动idea沙箱,网上有看到过教程离线导入这个IDEA的文件,不建议这样搞,非常麻烦且容易出错,为了避免后续bug存在,请等待10-30分钟

image.png

2.4 项目架构详解

项目结构图片

image.png

2.5 启动idea沙箱(IdeaIC)

点击启动后,可能还会下载一些依赖,请耐心等待。下载后的目录一般默认在用户目录下
image.png

通过gradle启动
image.png

通过快捷工具栏启动
image.pngimage.png

启动后会自动打开一个idea 这个是自动下载的沙箱版本和安装的是隔离的
image.png

三、编写人生之一个插件

组件类型描述接口plugin.xml加载配置元素
ApplicationComponet在idea启动时候初始化,整个IDEA只有一个实例ApplicationComponet<application-components>
ProjectComponentidea会为每一个Project实例创建对应级别的ComponentProjectComponent<project-components>
ModuleComponetidea会为每一个已经加载的Project中的每一个模块(module)创建Module级别的componentModuleComponet<module-componets>

先搞个和代码审计无关的插件,便于大家理解并提起你的兴趣,(#^.^#)

idea启动弹窗,人生鸡汤

1.在src/main/java下创建我们的pacage
image.png

2.新建一个applicationComponent的class文件
image.pngMyChickenSoul.java
这个文件是用来在启动时要做的事情,创建的类继承ApplicationComponent,然后重写initComponent ***

3.创建一个对话框
image.png

4.创建httpUtils
作用:请求公网免费鸡汤接口,额外使用的模块为httpclient,fastjson

5.导入额外jar包依赖
在build.gradle添加依赖,如何找到gradle依赖的?在Maven仓库搜索
image.png发现没有生效?点一下reload即可自动下载
image.png

6.plugin.xml 配置
添加application-component,将MyChickenSoul添加到配置文件。

7.启动插件
image.png有可能乱码的情况,我们可以在build.gradle配置文件最下方添加如下配置

                                
                                            

相关文章

游客坐车顶游北京野生动物园网友们炸了!园方工作人员是怎么回应的

今天,有网友发布一段视频称,北京野生动物园自驾区内,有游客坐在车顶上游园,非常危险。对此,园方工作人员表示,已联系上当事人,正在调查处理中。 野生动物园内 女孩坐车顶游园 从网传视频中可以看到,...

中国最大黑客组织C(国内最大的黑客组织)

中国最大黑客组织C(国内最大的黑客组织)

本文导读目录: 1、谁知道请问中国有哪些著名或者秘密的黑客组织? 2、中国十大Hacker组织? 3、中国最大的黑客组织是哪个 4、现在中国最权威的黑客组织是什么? 5、中国十大黑客排...

寻找黑客高手手机定位找人(专业黑客手机定位找人)

寻找黑客高手手机定位找人(专业黑客手机定位找人)

本文目录一览: 1、黑客能定位微信好友位置吗 2、问一下,有朋友找黑客追踪定位过手机号吗?会不会被骗啊? 3、要定位某个人的手机怎么用 黑客能定位微信好友位置吗 微信定位好友位置方法如下:1...

电脑左箭头怎么打出来(电脑键盘怎么打符号)

电脑左箭头怎么打出来(电脑键盘怎么打符号)

hello各位朋友们周六愉快,我是90小哥爱数码。 那么今天呢?我要与大家一起来分享一下,怎么样才能够在我们的电脑当中来打出各种各样的一些特殊的箭头符号。那么说到箭头符号呢,在我们的电脑中是经常被用...

个人投资入股协议书简单(个人投资协议合同范本)

  一、投资人个人信息和投资金额   姓名: 林x 入股金额:¥ 贰拾陆万肆千米整 (大写)   姓名: 陈xx 入股金额:¥ 壹拾叁万贰千米整 (大写)   姓名: 林x 入股金额:¥ 玖万陆千米整...

黑客用多大的笔记本(最适合黑客的笔记本)

黑客用多大的笔记本(最适合黑客的笔记本)

本文导读目录: 1、黑客们都用什么笔记本电脑 2、黑客用什么配置的电脑 3、黑客用什么电脑配置 4、玩黑客用的电脑配置 5、黑客配置什么笔记本电脑好? 6、请问黑客应该使用什么配置...