mirror of
https://github.com/github/codeql.git
synced 2025-12-16 08:43:11 +01:00
1.8 KiB
1.8 KiB
Improvements to Java analysis
Changes to existing queries
| Query | Expected impact | Change |
|---|---|---|
Implicit conversion from array to string (java/print-array) |
Fewer false positive results | Results in slf4j logging calls are no longer reported as slf4j supports array printing. |
Result of multiplication cast to wider type (java/integer-multiplication-cast-to-long) |
Fewer false positive results | Range analysis is now used to exclude results involving multiplication of small values that cannot overflow. |
Changes to QL libraries
- The
Guardslibrary has been extended to account for method calls that check conditions by conditionally throwing an exception. This includes thecheckArgumentandcheckStatemethods incom.google.common.base.Preconditions, theisTrueandvalidStatemethods inorg.apache.commons.lang3.Validate, as well as any similar custom methods. This means that more guards are recognized which improves the precision of a number of queries includingjava/index-out-of-bounds,java/dereferenced-value-may-be-null, andjava/useless-null-check. - The default sanitizer in taint tracking has been made more precise. The
sanitizer works by looking for guards that inspect tainted strings. It
previously worked at the level of individual variables. Now it
uses the
Guardslibrary, such that only guarded variable accesses are sanitized. This may give additional results for security queries. - Spring framework support now takes into account additional annotations that indicate remote user input. This affects all security queries, which may give additional results.