独家视频教程,玩转《阿里巴巴Java开发手册》P3C扫描插件

简介: 《阿里巴巴Java开发手册》IDE插件(包括PMD规则实现库)正式对外开源,如何快速掌握插件使用技巧,快速体验令人激动的自动化、智能化的插件协同工作?阿里巴巴Java开发手册P3C项目IDE插件主要开发者骏烈和云效在线扫描主要开发者胜燕,在云栖社区直播间,首次为大家提供视频教程,教大家玩转插件和在线扫描。
974713679d5fc7d1263f5038169b3d6461fec5e4
扫码或 点我直达 免费领

《阿里巴巴Java开发手册》IDE插件(包括PMD规则实现库)正式对外开源,如何快速掌握插件使用技巧,快速体验令人激动的自动化、智能化的插件协同工作?阿里巴巴Java开发手册P3C项目IDE插件主要开发者骏烈和云效在线扫描主要开发者胜燕,在云栖社区直播间,首次为大家提供视频教程,教大家玩转插件和在线扫描。

点击收看直播视频

插件操作

操作演示:大家结合 文档《阿里巴巴Java开发手册》IDEA插件与Eclipse插件使用指南直播视频一起看,效果会更好!

常见问题:

1.Code Style配置问题

很多用户提出希望能够提供一份统一的Code Style配置,但通过Eclipse、IDEA自己的配置无法做到两个平台完全统一。在各种取舍的情况下仍然会有几个不同点,如下:
  • 分号,IDEA设置的After Semicolon 会对for所有分号后面加空格,Eclipse 设置insert space after Semicolon in for则不会。
  • 缩进策略不一致,如方法调用折行后的缩进。
  • 类注释 IDEA会对描述进行缩进,Eclipse有配置项,但是同时对方法、类注释生效。

解决办法有两个:

  • 提供一份Eclipse的配置,IDEA端使用Eclipse Code Formatter之类的插件来做到格式化统一。但对于IDEA用户不够友好,也不够灵活。
  • 提供类似Google Code Format插件的功能,这个目前暂时还未做支持,感兴趣的同学可以联系我们。

2.Eclipse体验优化

目前已经有Eclipse方面的专家加入进来,各方面的优化、改进事项都在规划中,非常欢迎大家提出自己的宝贵意见或者加入进来。

3.eclipse-plugin、idea-plugin和p3c-pmd三个工程之间的关系

  • p3c-pmd提供大部分规则实现,基于PMD框架开发,如果想实现自己的规则,可以先看看PMD相关文档。
  • eclipse-plugin依赖p3c-pmd的实现,并且实现了4条需要跨文件扫描的规则。
  • IDEA与eclipse类似,也是依赖p3c-pmd的实现,同时实现了4条需要跨文件扫描的规则。

点击详情咨询


在线扫描

云效怎么做在线扫描,怎么与code集成?集成之后,怎么通过多维度的报表数据,来提升代码质量,最终达到公司代码规范统一?

案例分享:

首先,用IDE插件本地扫描的一个Demo。

b22e92cb6d15e2aa6c02534afee2831f579c5642

然后,我们会看到云效扫描的问题数,对应的扫描问题,以及在对应的代码多少行,都能够在云效系统看的清清楚楚。

026a105682b962903c967a38111a14c835e7114a

有时候开发只想知道增量有没有问题?历史问题太多修复不过来,我们需要保证新增的代码有没有问题。可以将P3C规则集成在code系统中,在阿里内部已经进行了这样一个集成。如下图所示,提交code review的时候,会自动将增量代码扫描,然后知道增量代码的质量是怎样的。

c1ca79abbc15d26ed850a15c9a74faf2def43179

这些都做完以后,我们可以将各类应用的代码扫描数据做成报表,每周可以发代码质量报告。俗话说得好,只有数据才能促进研发效能的提升。我们通过这份报表,看到谁做得好或不好,一目了然,逐渐地就可以将公司的代码规范,真正的工具化落地实施。

695315073f18bdfd136f01d838f8ff580f464354

在线扫描演示:(可结合 直播视频

首先,打开云效-测试服务 在线扫描入口,点击测试服务,然后点击阿里巴巴Java代码规约扫描,输一个测试任务名称,填写一下阿里云的代码库地址,将这个code代码库地址复制粘贴过来,代码分支不填的话默认是master分支,然后点击确定,确定以后在右上角点运行,就可以对这个代码库进行一个扫描。不仅可以扫描自己的代码,还可以扫描别人公开的代码。

195f1cd1140453356dde8f713f636da1fcb33b02

然后,刷新一下页面,大概等几十秒吧,可以看到下图显示的结果。可以看到这个代码库总共有62个问题,blockers是0,critical是1,然后major是61。点开可以看到报告的具体详情,比如哪些文件违反了哪些规则,以及哪些规则违反了多少次,都一目了然,接着可以对照这个报告来修复问题。当然我们会建议用户直接在本地进行修复。

60dac8357e2a8e87efb5bd541ce0fbdff3d7aa6a

除了提供扫描工具,云效还提供从“需求->开发->测试->发布->运维->运营”端到端的协同服务和研发工具支撑。在发布流程中,也可以加规约扫描。打开流水线项目,点击流水线,打开一个配好的,先构建然后进行代码规约的扫描,扫描后自动做一个单元测试,然后自动部署。

29e7bcd65f18a7ef43015df761ae940388233add

流水线有很多属性
可以扫描/长按识别下图二维码体验!
f85a34baedf7118487f1e7b06d70dc07742de56a


常见问题:

1.P3C怎么与gradle集成?
2.P3C怎么与maven集成?
3.P3C怎么与sonar集成?

其实很容易集成,因为P3C插件是基于PMD规则开发,可以参考PMD规则与gradle,maven,sonar集成代码。

参考链接:

如有其他问题,可以在本文留言哦~


相关文章
|
2月前
|
存储 Java
Java扫描某个文件夹且要保证不重复扫描,如何实现?
【10月更文挑战第18天】Java扫描某个文件夹且要保证不重复扫描,如何实现?
79 3
|
1月前
|
Java
轻松上手Java字节码编辑:IDEA插件VisualClassBytes全方位解析
本插件VisualClassBytes可修改class字节码,包括class信息、字段信息、内部类,常量池和方法等。
120 6
|
3月前
|
Arthas Java 测试技术
Java字节码文件、组成,jclasslib插件、阿里arthas工具,Java注解
Java字节码文件、组成、详解、分析;常用工具,jclasslib插件、阿里arthas工具;如何定位线上问题;Java注解
Java字节码文件、组成,jclasslib插件、阿里arthas工具,Java注解
|
3月前
|
安全 Oracle Java
edge浏览器加载java插件
edge浏览器加载java插件
255 1
|
3月前
|
XML JavaScript Java
NekoHTML 是一个基于Java的HTML扫描器和标签补全器
**NekoHTML** 是一个基于Java的HTML扫描器和标签补全器(tag balancer),由J. Andrew Clark开发。它主要用于解析HTML文档,并能够“修正”许多在编写HTML文档过程中常犯的错误,如增补缺失的父元素、自动用结束标签关闭相应的元素,以及处理不匹配的内嵌元素标签等。这使得程序能够以标准的XML接口来访问HTML文档中的信息。 ### NekoHTML的主要特点包括: 1. **错误修正**:能够自动修正HTML中的常见错误,如未闭合的标签等。 2. **DOM树生成**:将HTML源代码转化为DOM(Document Object Model)结构,便
|
3月前
|
算法 Oracle Java
Java字符串拼接技术演进及阿里巴巴的贡献
本文主要讲述了Java字符串拼接技术的演进历程,以及阿里巴巴贡献的最新实现 PR 20273。
142 11
|
3月前
|
安全 Java 关系型数据库
代码规范Java阿里巴巴
本文介绍了阿里巴巴的《Java开发手册》,这是一份业界公认的代码规范手册,涵盖编程规约、异常日志、单元测试、安全规约、MySQL数据库、工程结构、设计规约七个维度。手册通过强制、推荐、参考三大类规约,详细指导开发者编写高质量的Java代码。文中还提供了常见问题的正反例对比,如方法参数类型一致性、SimpleDateFormat线程安全等问题的解决方案。此外,还介绍了如何安装和使用阿里规范插件来提高编码效率。
743 9
|
3月前
|
算法 Oracle Java
Java字符串拼接技术演进及阿里巴巴的贡献
本文主要讲述了Java字符串拼接技术的演进历程,以及阿里巴巴贡献的最新实现 PR 20273。
105 12
|
4月前
|
小程序 JavaScript Java
【资料】阿里Java开发手册
本文是关于分享阿里Java开发手册资源及促进编程规范学习的指南。作者以个人经历引入,讲述了公司领导通过细致讲解阿里Java开发手册,提升了团队对代码质量和编程规范的认识
1062 0
【资料】阿里Java开发手册
|
4月前
|
存储 Java 测试技术
阿里巴巴java开发手册
这篇文章是关于阿里巴巴Java开发手册的整理,内容包括编程规约、异常日志、单元测试、安全规约、MySQL数据库使用以及工程结构等方面的详细规范和建议,旨在帮助开发者编写更加规范、高效和安全的代码。