Abstract
Multiple validation forms with the same name indicate
that validation logic is not up-to-date.
Description
If two validation forms have the same name, the
Struts Validator arbitrarily chooses one of the forms to
use for input validation and discards the other. This
decision might not correspond to the programmer's
expectations. Moreover, it indicates that the validation
logic is not being maintained, and can indicate that
other, more subtle, validation errors are present.
Examples
Two validation forms with the same name.
<form-validation>
<formset>
<form name="ProjectForm">
...
</form>
<form name="ProjectForm">
...
</form>
</formset>
</form-validation>
It is critically important that validation logic be
maintained and kept in sync with the rest of the
application. Unchecked input is the root cause of some
of today's worst and most common software security
problems. Cross-site scripting, SQL injection, and
process control vulnerabilities all stem from incomplete
or absent input validation. Although J2EE applications
are not generally susceptible to memory corruption
attacks, if a J2EE application interfaces with native
code that does not perform array bounds checking, an
attacker may be able to use an input validation mistake
in the J2EE application to launch a buffer overflow
attack.