|Home > Security Bulletins > S2-010|
When using Struts 2 token mechanism for CSRF protection, token check may be bypassed by misusing known session attributes
|Who should read this||All Struts 2 developers|
|Impact of vulnerability||CSRF protection weakening|
|Maximum security rating||Moderate|
|Recommendation||Developers should upgrade to Struts 18.104.22.168|
|Affected Software||Struts 2.0.0 - Struts 2.3.4|
|Original JIRA Tickets||WW-3858|
|Reporter||James K. Williams|
The Struts 2 token mechanism (token tag and token interceptors) was originally targeted at providing double submit check for forms.
In addition the mechanism basically qualifies for CSRF protection by implementing the Synchronizer Token Pattern, as described in the OWASP CSRF Prevention Cheat Sheet.
When used for that purpose, a possible attacker might manipulate a request by changing the token name configuration parameter to match a String typed session attribute known to him by name and value, along with changing the token value parameter to the value of the said session attribute. The token check mechanism is then bypassed by the existent session attribute matching the request's token configuration.
As of Struts 22.214.171.124, token session attribute names are decoupled from token parameter names by namespace prefixing.
Please upgrade to Struts 126.96.36.199.