我在请求范围的托管bean中使用了bean验证。
@ManagedBean(name = "loginController")
@RequestScoped
public class LoginController implements Serializable {
private static final long serialVersionUID = -7174581953062231554L;
@NotNull(message = "Password!")
private String mPassword;
@NotNull
private String mUsername;
...
...
public String login() {
..
return "destination.xhtml";
}
..并且在web.xml中我已将此配置为将空字符串解释为空值:
<context-param>
<param-name>javax.faces.INTERPRET_EMPTY_STRING_SUBMITTED_VALUES_AS_NULL</param-name>
<param-value>true</param-value>
</context-param>
视图看起来像这样:
<h:form id="login">
<h3><h:outputText value="Username" /></h3>
<h:inputText id="username" value="#{loginController.username}" />
<h3><h:outputText value="Password" /></h3>
<h:inputSecret id="password" value="#{loginController.password}" autocomplete="off" />
<h:commandButton id="submit" value="Login" action="#{loginController.login}">
<f:param name="redirect" value="#{requestScope['javax.servlet.forward.request_uri']}" />
</h:commandButton>
</h:form>
环境:Glassfish 3.1.1 / Mojarra JSF 2.1
问题:当按下提交按钮而不填写用户名或密码字段时,将执行操作,但注释(@ javax.validation.constraints.NotNull)应该阻止此操作。验证不起作用! 将“required”属性添加到字段将解决此问题,但我不希望视图中的验证逻辑。 你对我有什么建议吗?
更新
基本上,上面的代码有效。我在一个单独的项目中测试过它。 在另一个仍然不起作用的项目中,情况有所不同。表单在web.xml文件中配置为登录表单(login-config)。这是否会在jsf生命周期中进行一些更改? ..还是别的什么?
答案 0 :(得分:0)
你的验证不是关于String.empty而是“notnull”吗? 特别是如果数据来自表单,则字符串的“null”值不应存在。
必需
必需属性是一个布尔标志,指示是否 用户需要在表单之前为此字段提供值 可以提交到服务器
也许,在@NotNull之下,你可以尝试添加
@Size(min=1, max=X)
见这里:http://download.oracle.com/javaee/6/tutorial/doc/gircz.html