SonarQube 简介
Sonar 是一个用于代码质量管理的开放平台。通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具。
与持续集成工具(例如 Hudson/Jenkins 等)不同,Sonar 并不是简单地把不同的代码检查工具结果(例如 FindBugs,PMD 等)直接显示在 Web 页面上,而是通过不同的插件对这些结果进行再加工处理,通过量化的方式度量代码质量的变化,从而可以方便地对不同规模和种类的工程进行代码质量管理。
在对其他工具的支持方面,Sonar 不仅提供了对 IDE 的支持,可以在 Eclipse 和 IntelliJ IDEA 这些工具里联机查看结果;同时 Sonar 还对大量的持续集成工具提供了接口支持,可以很方便地在持续集成中使用 Sonar。
此外,Sonar 的插件还可以对 Java 以外的其他编程语言提供支持,对国际化以及报告文档化也有良好的支持
1."@RequestMapping" 方法应为“ public”
将调用具有@Controller注释的类的@RequestMapping注释部分的方法(直接或间接通过元注释-Spring Boot的@RestController是一个很好的示例)来处理匹配的Web请求。即使该方法是私有的,也会发生这种情况,因为Spring会通过反射调用此类方法,而不检查可见性。
因此,将敏感方法标记为私有似乎是控制如何调用此类代码的好方法。不幸的是,并非所有的Spring框架都以这种方式忽略可见性。例如,如果您试图通过将其标记为@Secured来控制对敏感,私有@RequestMapping方法的Web访问,则无论用户是否被授权访问它,它仍将被调用。这是因为AOP代理不适用于非公开方法。
除了@RequestMapping之外,此规则还考虑了Spring Framework 4.3中引入的注释:@ GetMapping,@ PostMapping,@ PutMapping,@ DeleteMapping,@ PatchMapping。
2.默认软件包中不应使用“ @SpringBootApplication”和“ @ComponentScan”
@ComponentScan用于确定哪些Spring Bean在应用程序上下文中可用。可以使用basePackageClasses或basePackages(或其别名值)参数来配置要扫描的软件包。如果未配置任何参数,则@ComponentScan将仅考虑带有注释的类的程序包。在属于默认包的类上使用@ComponentScan时,将扫描整个类路径。
这将减慢应用程序的启动速度,并且该应用程序可能无法启动BeanDefinitionStoreException,因为您最终扫描了Spring Framework软件包本身。
在以下情况下,此规则会引起问题:
@ ComponentScan,@ SpringBootApplication和@ServletComponentScan用于默认包的类
@ComponentScan已使用默认程序包显式配置
不兼容代码示例
import org.springframework.boot.SpringApplication;
@SpringBootApplication