Movatterモバイル変換


[0]ホーム

URL:


CodeQL documentation
CodeQL resources

Uncontrolled data in arithmetic expression

ID: java/uncontrolled-arithmeticKind: path-problemSecurity severity: 8.6Severity: warningPrecision: mediumTags:   - security   - external/cwe/cwe-190   - external/cwe/cwe-191Query suites:   - java-security-extended.qls   - java-security-and-quality.qls

Click to see the query in the CodeQL repository

Performing calculations on uncontrolled data can result in integer overflows unless the input is validated.

If the data is not under your control, and can take extremely large values, even arithmetic operations that would usually result in a small change in magnitude may result in overflows.

Recommendation

Always guard against overflow in arithmetic operations on uncontrolled data by doing one of the following:

  • Validate the data.

  • Define a guard on the arithmetic expression, so that the operation is performed only if the result can be known to be less than, or equal to, the maximum value for the type, for exampleMAX_VALUE.

  • Use a wider type, so that larger input values do not cause overflow.

Example

In this example, a random integer is generated. Because the value is not controlled by the programmer, it could be extremely large. Performing arithmetic operations on this value could therefore cause an overflow. To avoid this happening, the example shows how to perform a check before performing a multiplication.

classTest{publicstaticvoidmain(String[]args){{intdata=(newjava.security.SecureRandom()).nextInt();// BAD: may overflow if data is largeintscaled=data*10;// ...// GOOD: use a guard to ensure no overflows occurintscaled2;if(data<Integer.MAX_VALUE/10)scaled2=data*10;elsescaled2=Integer.MAX_VALUE;}}}

References


[8]ページ先頭

©2009-2025 Movatter.jp