зеркало из https://github.com/github/codeql.git
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
Guards
library has been extended to account for method calls that check conditions by conditionally throwing an exception. This includes thecheckArgument
andcheckState
methods incom.google.common.base.Preconditions
, theisTrue
andvalidState
methods 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
Guards
library, 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.