Skip to content

Commit

Permalink
Merge branch 'master' into BUILD-4733
Browse files Browse the repository at this point in the history
  • Loading branch information
tomverin authored Jun 24, 2024
2 parents 7e40d76 + 9b486fd commit cdc5e57
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 0 deletions.
53 changes: 53 additions & 0 deletions rules/S5334/java/how-to-fix-it/jsp.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
== How to fix it in JSP

=== Code examples

The following code is vulnerable to arbitrary code execution because it compiles
and runs HTTP data.

==== Noncompliant code example

[source,java,diff-id=21,diff-type=noncompliant]
----
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags" %>
<spring:eval expression="${tainted}" var="result"/>
----

==== Compliant solution

It is not possible to securely include user input in a SpEL expression inside of
the template. Evaluate the expression in the controller and pass the result to
the template instead.

[source,java,diff-id=21,diff-type=compliant]
----
import org.springframework.expression.Expression;
import org.springframework.expression.ExpressionParser;
import org.springframework.expression.spel.standard.SpelExpressionParser;
import org.springframework.ui.Model;
@Controller
public class ExampleController
{
@GetMapping(value = "/")
public void exec(@RequestParam("message") String message, Model model) {
StandardEvaluationContext evaluationContext = new StandardEvaluationContext();
evaluationContext.setVariable("msg", message);
ExpressionParser parser = new SpelExpressionParser();
Expression exp = parser.parseExpression("#msg");
String result = (String) exp.getValue(evaluationContext);
model.addAttribute("result", result);
}
}
----

=== How does this work?

include::../../common/fix/introduction.adoc[]

include::../../common/fix/parameters.adoc[]

The compliant code example uses such an approach.

include::../../common/fix/allowlist.adoc[]
3 changes: 3 additions & 0 deletions rules/S5334/java/metadata.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@
"5.1.4",
"5.2.4",
"5.5.4"
],
"STIG ASD 2023-06-08": [
"V-222609"
]
}
}
2 changes: 2 additions & 0 deletions rules/S5334/java/rule.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ include::../impact.adoc[]

include::how-to-fix-it/commons-compiler.adoc[]

include::how-to-fix-it/jsp.adoc[]

include::how-to-fix-it/spring.adoc[]

== Resources
Expand Down

0 comments on commit cdc5e57

Please sign in to comment.