Ich arbeite an einem Struts 2-Projekt, das Problem ist, dass ich <constant name="struts.ui.theme" value="simple"/>
in meinem struts.xml
für das Layout meiner JSP-Seite verwenden (z. B. 2-3 Textfiled in einer Zeile mit Tablecode anordnen)) gemäß dem angewendeten CSS, aber ich bin nicht in der Lage, den Validierungsfehler auf derselben jsp-Seite aufgrund von theme="simple"
anzuzeigen.Die Validierung und Thema in Struts 2
Konfiguration:
<struts>
<!-- Configuration for the default package. -->
<constant name="struts.ui.theme" value="simple"/>
<package name="default" extends="struts-default">
<action name="validateUser" class="login.LoginAction">
<result name="SUCCESS">/welcome.jsp</result>
<result name="input">/login.jsp</result>
</action>
</package>
</struts>
Aktion:
public class LoginAction extends ActionSupport{
private String username; // getter and setter
private String password; // getter and setter
@Override
public String execute() {
// some business logic here....
return "SUCCESS";
}
//simple validation
@Override
public void validate(){
if("".equals(getUsername())){
addFieldError("username", getText("username.required"));
}
if("".equals(getPassword())){
addFieldError("password", getText("password.required"));
}
}
}
Ausblick:
<s:form action="validateUser" validate="true" >
<table>
<tr>
<td>username</td>
<td><s:textfield label="username" name="username" /><td/>
</tr>
<tr>
<td>password</td>
<td><s:password label="password" name="password" /><td/>
<tr>
<td> <s:submit label="submit" name="submit"/></td>
</tr>
</table>
</s:form>
Gibt es eine Möglichkeit zu halten das Layout mit meinem CSS und benutze auch Struts 2 Validierung?