SonarQube 检测出的 bug、漏洞以及异味的修复整理,mysql 基础知识
[](
)12.Remove the unboxing from “Integer”
data:image/s3,"s3://crabby-images/1465a/1465a2a20a5b48499ae19983c243721182ea173a" alt=""
提示是这个 Integer 封装是多余的,所以直接用强类型转换就可以吧。
data:image/s3,"s3://crabby-images/a9976/a9976ef13b0befeb99547bc140f3a13d42ed3be2" alt=""
[](
)13.Use another way to initialize this instance
data:image/s3,"s3://crabby-images/fecc8/fecc89541cef0eee0503111e14aa50ea47d9082e" alt=""
这个提示用其他的方式初始化,不要在定义的时候就初始化,修改如下:
data:image/s3,"s3://crabby-images/62944/62944e767a7b8cf4d834afd5cf86eabd669fb4d2" alt=""
遇到的基本上就是这些 bug 了,还有 css 中的一些 bug,按照提示修改的
[](
)14.Unexpected missing generic font family
data:image/s3,"s3://crabby-images/1a5d5/1a5d562dc03866f3c5af4a79770c93d985325ae3" alt=""
将这两个 body 的样式合二为一,可以消除 bug 和漏洞
[](
)15.Unexpected duplicate “display”
data:image/s3,"s3://crabby-images/2c6a1/2c6a1d30a7e1aa494bb834237ff701722479c4f2" alt=""
Display 重复了,删除掉一个。
[](
)16.Unexpected unknown type selector “element”
data:image/s3,"s3://crabby-images/862b6/862b64a5ab3cf9131ce0938e758c4329527a96ad" alt=""
空样式,直接删除掉。
[](
)17. Change this condition so that it does not always evaluate to “false”
(更改此条件,以便它不总是评估为“false")
这是很多 webservice 文件中出现的一个 bug。 如果后期会对 webservice 文件过滤,这个就可以不管了。不过也可以把这行删除掉,obj 不可能为 null if (obj == null) return false; 这样这个 bug 也没有了。
data:image/s3,"s3://crabby-images/c691b/c691b0a280c6260de0b60f6ddadf4995686acf64" alt=""
[](
)二 漏洞
[](
)1.Use a logger to log this exception
data:image/s3,"s3://crabby-images/d7a9d/d7a9d34d5222dcead14466f6261c33151e0c38be" alt=""
这种提示就是异常应该用日志打印出来。
data:image/s3,"s3://crabby-images/fa75b/fa75bcf5b0a635906942aed8cf39ca076826fc8e" alt=""
[](
)2.‘password’ detected in this expression, review this potentially hard-coded credential
data:image/s3,"s3://crabby-images/1a47e/1a47ea9200220c301654dca1902dbc3fd31631aa" alt=""
提示密码不能直接这样传递,不安全。但是也没有提供参考的案例。所以我是这样的改的,也能消除漏洞。如下图:
data:image/s3,"s3://crabby-images/710f9/710f9115d903fd637d7d3dacec26f92d99bcf4ec" alt=""
[](
)3.Make areaList a static final constant or non-public and provide accessors if needed
data:image/s3,"s3://crabby-images/4cbdc/4cbdc65ca2ec49a59ab0450657f519864f49711b" alt=""
类变量字段不应具有公共可访问性。所以把 public 访问修饰符,改成其他的修饰符,最好是 private.
data:image/s3,"s3://crabby-images/dd252/dd252fd3f46903bc35a8de9fe60a97f2b66f4dd4" alt=""
[](
)4.Secure this “Transformer” by either disabling external DTDs or enabling secure processing.
data:image/s3,"s3://crabby-images/7412c/7412c0fc1d4fb147053eeec90f7cd362e086b818" alt=""
提示应该保护 XML 变换器。创建 javax.xml.transform.Transformer 但未启用“安全处理”或创建一个而不禁用外部 DTD 时,可能会发生 XML 外部实体或 XSLT 外部实体(XXE)漏洞。 如果该外部实体被攻击者劫持,则可能导致机密数据泄露,拒绝服务,服务器端请求伪造,从解析器所在机器的角度进行端口扫描,以及其他系统影响。
进行修改如下可以消除漏洞:
data:image/s3,"s3://crabby-images/1c982/1c9827bd3049d7233050df4cefc4fc039e86bffa" alt=""
[](
)5.Do something with the “boolean” value returned by “delete”.
data:image/s3,"s3://crabby-images/9dc72/9dc72a43da07dcb565a12f441742ed7628d80627" alt=""
提示当包含操作状态代码时,不应忽略返回值。也就是说不应该忽略文件删除操作的结果。
所以进行如下修改,但是如下修改虽然修复了漏洞,但是新增了异味。
data:image/s3,"s3://crabby-images/a75d9/a75d94ce582c80763b1f20afa37c5ada9122c4cb" alt=""
异味提示"java.nio.Files#delete" should be preferred (squid:S4042)。应该使用 Files.delete()方法,而不能之间文件 delete.所以最后修改成:
data:image/s3,"s3://crabby-images/699dc/699dc8c66852ad04ed44da23b3e05b517a224e69" alt=""
[](
)6.Make this “public static userInfoUrl” field final
data:image/s3,"s3://crabby-images/fd937/fd937823db6cf394c4003d5259317fbbffd5b0b2" alt=""
这种“public static”字段应该成员变量应该是不变的,所以需要加上 final 修饰,如下:
data:image/s3,"s3://crabby-images/4583a/4583aee8889f4afd6ceab00cb13196a83e88fe5c" alt=""
还有几种漏洞不好修复,暂时没有思路
[](
)7.Change this method so it throws exceptions
data:image/s3,"s3://crabby-images/7c5d4/7c5d49f031a6698b09656edf66c150246d6c3e7f" alt=""
这种提示,TrustManagers 不应盲目接受任何证书。通常会创建 X509TrustManager 接口的空实现,以允许连接到未由根证书颁发机构签名的主机。 这样的实现将接受任何证书,这使得应用程序容易受到中间人攻击。 正确的解决方案是提供适当的信任存储。
[](
)8.Use the recommended AES (Advanced Encryption Standard) instead.
data:image/s3,"s3://crabby-images/9d91b/9d91bf7c2213f33866cd3bb0423f5ed3773ea6e8" alt="在这里插入图片描述"
这种原来用 DES 加密的提示不应使用 DES(数据加密标准)和 DESede(3DES)。它推荐的使用 AES.但是将 DES 加密改成 AES 加密虽然程序异味消除了,但是程序肯定不对吧,加密方式换了肯定会出问题的吧。
[](
)三 异味
异味太多了,我也没有消除太多了异味,一个项目异味一般都是好几 k,所以消除起来一两个异味对基数没有什么影响,并且异味太多,消除一部分后,并没有感受到那种异味数量巨减的感觉,导致消除异味的积极性不是很高。并且有的异味是真的不好消除,有时候打开一个文件,几千行代码一片都是标异味。直接就放弃了。
[](
)1.Replace the type specification in this constructor call with the diamond operator ("<>").
data:image/s3,"s3://crabby-images/9cef6/9cef6dc421b6762220d995a0b01d0d216248306e" alt=""
Java 7 引入了菱形运算符(<>)来减少泛型代码的冗长。 例如,您现在可以使用<>简化构造函数声明,而不必在其声明及其构造函数中声明 List 的类型,编译器将推断该类型。如下:
data:image/s3,"s3://crabby-images/bd9cc/bd9cc8951ac01c660923351e25cd26acc73e870a" alt=""
[](
)2.Add a default case to this switch
data:image/s3,"s3://crabby-images/45caf/45caf10c3274ba97d4ab4b3db2bb8c3daa2320ca" alt=""
swatch 中没有 default,也没有 break;虽然上面的代码不要 break 也不会有什么问题。但是万一哪天变了,不是 return 就很容易出错了吧。
[](
)3.Remove this empty statement.
data:image/s3,"s3://crabby-images/68ba9/68ba957fcc993e2f08836da239ccc43c66050330" alt=""
两个分号,代码中有很多地方有这种情况感觉,删掉多余的。
[](
)4.Remove this useless assignment to local variable “XXX”.
data:image/s3,"s3://crabby-images/82e2b/82e2b1faa25a2c18b75113d97a9797d192da5dc2" alt=""
上图,定义的变量但是没有使用,就会抛出这种异味,解决这种异味,是需要看看这个变量有什么作用,没有作用的可以删除掉,如果不改随意改动,可以在他们下面增加一条日志打印他们,这样也能消除这个异味。
[](
)5.Directly append the argument of String.valueOf().
data:image/s3,"s3://crabby-images/420e3/420e3be4755bf0ba18e340ebbdc16742f2e07d06" alt=""
String.valueOf()不应附加到 String。这里我的理解是,result 是 string 类型,arerType 是 int 类型,在拼接的时候会自动的将 int 类型转换成 string,不用多此一举。
data:image/s3,"s3://crabby-images/0ba8a/0ba8a8f012b499ae082c756b550b850ec0a51769" alt=""
[](
)6.Define a constant instead of duplicating this literal “XXXX” 4 times.
data:image/s3,"s3://crabby-images/788d0/788d09882861dec223f82094aa12b1bb2e8f8b2c" alt=""
类似这种,当一个不变的字符串在一个文件中多次出现,就应该给这些字符串提取成常量,这样方便以后修改和维护。但是说实话提取常量这个异味真的很枯燥,并且代码中有大量的这种情况,感觉每个项目或者每个模块都应该提取一个常量类,这样这个模块用到这些不变字符串,就直接从这个类中获取,但是这个工作量有点大哈哈,我就简单的尝试了一下,把自定义报表那部分提取常量,但是进行了一部分就没有进行下去了,枯燥且工作量大
data:image/s3,"s3://crabby-images/63036/63036e0d028fdd7a958a9f8ae9093fa2ad9e35b5" alt=""
data:image/s3,"s3://crabby-images/e6da7/e6da74e231aee0f1708e7d1b8bbce4a02a89baf6" alt=""
但是我觉得这个工作还是做比较好,这样便于以后的维护,常量值改变只用改一个地方就好了,不用所有地方都修改。
[](
)7.Use a StringBuilder instead.
data:image/s3,"s3://crabby-images/6e605/6e605957c613597ce4d829b4ab6f531d1fc031ad" alt=""
当字符串需要频繁变化时,用 stringBuilder 代替 string .这里还有一种异味是代码中有的地方用的是 StringBuffer,也需要转成 StringBuilder.因为 Stringbuffer 是确保线程安全的,stringBuilder
不用,所以 stringBuilder 效率更高。那会不会引发线程安全问题呢,不会,因为这个是在方法内部定义的变量,所以对这个方法而言是线程封闭的,不会引发线程安全问题。
[](
)8.Reorder the modifiers to comply with the Java Language Specification.
data:image/s3,"s3://crabby-images/018a6/018a695e6a9c54ba565be5d7886a604f129c33a4" alt=""
提示修饰符的顺序应该符合 java 语言规范,它给出的参考如下:
data:image/s3,"s3://crabby-images/5b4ee/5b4ee973e6e5cee3c414d4284d5188bb51756b18" alt=""
所以把 static 修饰符 放到 final 就好了。
[](
)9.Declare “XXX” on a separate line.
data:image/s3,"s3://crabby-images/04b56/04b568938ab23f9142f1eeacebec23e91c56c679" alt=""
定义变量的时候,一个变量一行,便于查看
data:image/s3,"s3://crabby-images/b2cb9/b2cb9addf897b725f6be91cce4cdfd4b74da01e2" alt=""
[](
)10.Return an empty collection instead of null.
data:image/s3,"s3://crabby-images/ce512/ce51225f15201d499e9cb3dea4cca3e66c125c20" alt=""
最好不要直接返回 null,应返回空数组和集合.如下:
data:image/s3,"s3://crabby-images/df15c/df15cdaff95a8de65200dedaa7d97e12fa9b035a" alt=""
[](
)11.Use isEmpty() to check whether the collection is empty or not.
data:image/s3,"s3://crabby-images/1c45b/1c45b8436c017a3ca470f1d786ab96001be90f52" alt=""
判断集合时候为空是,不要使用 size(),建议使用 isEmpty()方法。如下:
data:image/s3,"s3://crabby-images/23049/23049cf3d2deb35c7e5a78108b2a4197de1fdbb3" alt=""
[](
)12.This block of commented-out lines of code should be removed
data:image/s3,"s3://crabby-images/08271/08271323ace5815899da532b91c277edd5b8898f" alt=""
这种可以直接删除掉,或者不想删除的可以用/***/注释,对于单行的可以把后面的分号去掉就不会报错异味了。
data:image/s3,"s3://crabby-images/94944/949443633fab9b582e6ce5f46805401d68f80412" alt=""
[](
)13.Remove the literal “false” boolean value
data:image/s3,"s3://crabby-images/bde84/bde8441f5ebe7ffe180d65d2b6982b52f077db04" alt=""
布尔文字不应该是多余的。用 true 或者 false 在 if 中判断是不好的写好,直接可以通过本身进行判断,如下:
data:image/s3,"s3://crabby-images/3397d/3397dbc007f641e024b35e0e6716e5b9e0cff0bd" alt=""
[](
)14.Add a private constructor to hide the implicit public one.
data:image/s3,"s3://crabby-images/61403/614034522712a9839c51d1f07a38d749eb920a9d" alt=""
如果一个类的里面的方法都是 static 修饰的静态方法,那么需要给这个类定义一个非公共构造函数(添加私有构造函数以隐藏隐式公共构造函数)如下:
data:image/s3,"s3://crabby-images/54d28/54d28ee238cff239f5bf37d9d0685c8e608ab0db" alt=""
[](
)15.Refactor this method to reduce its Cognitive Complexity from 55 to the 15 allowed.
data:image/s3,"s3://crabby-images/de322/de32282fa7732a21db8fc371445fafe737787c69" alt=""
关于代码圈复杂度大于 15 的异味,以及代码过长的异味,说实话也没有什么好的方法,只能读代码,然后抽离函数出来,当然抽离函数不可能一次就能做到代码简洁之道要求的那样,一个函数只做一件事,单一层次原则。但是我们也不能因为做不到这样就就什么都不做,还是要迈出这一步,先抽离函数,虽然没有做到单一层次原则,但是消除了异味。下面代码是对上面的进行简单的函数抽离,消除异味
data:image/s3,"s3://crabby-images/408c6/408c62d9a80ff4c14584e4289ba1955f5c400fe1" alt=""
[](
)16.关于代码中很多的 stitch 分支问题。
评论