Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jsf-2/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Jsf 2 bean验证和jsf2集成_Jsf 2_Bean Validation_Hibernate Validator - Fatal编程技术网

Jsf 2 bean验证和jsf2集成

Jsf 2 bean验证和jsf2集成,jsf-2,bean-validation,hibernate-validator,Jsf 2,Bean Validation,Hibernate Validator,我使用此处描述的跨域验证作为示例 它们可以完美地工作,并抛出一个javax.ejb.EJBTransactionRolledbackException以及所有违反的约束的列表。但是我需要在元素中显示错误消息。从来都不是。是因为这是类级注释吗?字段上注释的验证始终在页面上显示其消息 有人能解释一下吗 凯利 更新: 我不会发布验证器,因为它们是从链接上的示例复制和粘贴的,但我的页面是这样的 <h:form id="registration_form" class="form-horizonta

我使用此处描述的跨域验证作为示例

它们可以完美地工作,并抛出一个javax.ejb.EJBTransactionRolledbackException以及所有违反的约束的列表。但是我需要在元素中显示错误消息。从来都不是。是因为这是类级注释吗?字段上注释的验证始终在页面上显示其消息

有人能解释一下吗

凯利

更新:

我不会发布验证器,因为它们是从链接上的示例复制和粘贴的,但我的页面是这样的

<h:form id="registration_form" class="form-horizontal" prependId="false">
  <h:messages errorClass="alert alert-error no-bullets" infoClass="alert alert-info no-bullets" globalOnly="false"/>
<div class="form-actions">
 <h:commandButton id="create_button" value="#{label['save']}" action="#{actionBean[save]}" class="btn btn-primary" />
<button class="btn">#{label['cancel']}</button>
</div>
  </div>
我的托管bean:

@Named("userBean")
@Stateful
@ConversationScoped
 public class UserBean implements Serializable {
   @Inject
private Conversation conversation;
@EJB
private UserManagerBeanLocal userController;
public String update() {
   //calls a method that only has entityManager.persist();
    }
}
调用具有entityManager.persist的方法时,会引发异常,堆栈跟踪上会显示所有约束冲突,但@compareStrings页面中不会显示任何冲突。如果仅违反@notblank(或字段上的任何其他注释),则正确显示消息

更新2


Kelly你能给我们一个简短的代码示例吗?您的问题标题涉及JSF,但您的异常说明了一些关于EJB的内容。我想这基本上回答了我的问题。。。。
@Named("userBean")
@Stateful
@ConversationScoped
 public class UserBean implements Serializable {
   @Inject
private Conversation conversation;
@EJB
private UserManagerBeanLocal userController;
public String update() {
   //calls a method that only has entityManager.persist();
    }
}
    17:10:47,980 ERROR [org.jboss.ejb3.tx2.impl.CMTTxInterceptor]     javax.ejb.EJBTransactionRolledbackException: Validation failed for classes     [com.sample.domain.User] during persist time for groups [javax.validation.groups.Default, ]
    List of constraint violations:[
        ConstraintViolationImpl{interpolatedMessage='com.sample.business.validation.PASSWORDS_DONT_M    ATCH', propertyPath=password, rootBeanClass=class com.sample.domain.User,     messageTemplate='com.sample.business.validation.PASSWORDS_DONT_MATCH'}
        ConstraintViolationImpl{interpolatedMessage='com.sample.business.validation.PASSWORDS_DONT_M    ATCH', propertyPath=passwordConfirmation, rootBeanClass=class com.sample.domain.User,     messageTemplate='com.sample.business.validation.PASSWORDS_DONT_MATCH'}
    ]
    17:10:47,985 WARNING [javax.enterprise.resource.webcontainer.jsf.lifecycle] #{actionBean[save]}: javax.ejb.EJBTransactionRolledbackException: Validation failed for classes [com.sample.domain.User] during persist time for groups [javax.validation.groups.Default, ]
List of constraint violations:[
    ConstraintViolationImpl{interpolatedMessage='com.sample.business.validation.PASSWORDS_DONT_MATCH', propertyPath=password, rootBeanClass=class com.sample.domain.User, messageTemplate='com.sample.business.validation.PASSWORDS_DONT_MATCH'}
    ConstraintViolationImpl{interpolatedMessage='com.sample.business.validation.PASSWORDS_DONT_MATCH', propertyPath=passwordConfirmation, rootBeanClass=class com.sample.domain.User, messageTemplate='com.sample.business.validation.PASSWORDS_DONT_MATCH'}
]: javax.faces.FacesException: #{actionBean[save]}: javax.ejb.EJBTransactionRolledbackException: Validation failed for classes [com.sample.domain.User] during persist time for groups [javax.validation.groups.Default, ]
List of constraint violations:[
    ConstraintViolationImpl{interpolatedMessage='com.sample.business.validation.PASSWORDS_DONT_MATCH', propertyPath=password, rootBeanClass=class com.sample.domain.User, messageTemplate='com.sample.business.validation.PASSWORDS_DONT_MATCH'}
    ConstraintViolationImpl{interpolatedMessage='com.sample.business.validation.PASSWORDS_DONT_MATCH', propertyPath=passwordConfirmation, rootBeanClass=class com.sample.domain.User, messageTemplate='com.sample.business.validation.PASSWORDS_DONT_MATCH'}
]
    at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:118) [:2.1.6-SNAPSHOT]
    at javax.faces.component.UICommand.broadcast(UICommand.java:315) [:2.1.6-SNAPSHOT]
    at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:794) [:2.1.6-SNAPSHOT]
    at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1259) [:2.1.6-SNAPSHOT]
    at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81) [:2.1.6-SNAPSHOT]
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101) [:2.1.6-SNAPSHOT]
    at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118) [:2.1.6-SNAPSHOT]
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:593) [:2.1.6-SNAPSHOT]
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:324) [:6.1.0.Final]
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:242) [:6.1.0.Final]
    at org.jboss.weld.servlet.ConversationPropagationFilter.doFilter(ConversationPropagationFilter.java:67) [:6.1.0.Final]
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:274) [:6.1.0.Final]
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:242) [:6.1.0.Final]
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:275) [:6.1.0.Final]
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161) [:6.1.0.Final]
    at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:181) [:6.1.0.Final]
    at org.jboss.modcluster.catalina.CatalinaContext$RequestListenerValve.event(CatalinaContext.java:285) [:1.1.0.Final]
    at org.jboss.modcluster.catalina.CatalinaContext$RequestListenerValve.invoke(CatalinaContext.java:261) [:1.1.0.Final]
    at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:88) [:6.1.0.Final]
    at org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.invoke(SecurityContextEstablishmentValve.java:100) [:6.1.0.Final]
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:159) [:6.1.0.Final]
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) [:6.1.0.Final]
    at org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:158) [:6.1.0.Final]
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) [:6.1.0.Final]
    at org.jboss.web.tomcat.service.request.ActiveRequestResponseCacheValve.invoke(ActiveRequestResponseCacheValve.java:53) [:6.1.0.Final]
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:362) [:6.1.0.Final]
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:877) [:6.1.0.Final]
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:654) [:6.1.0.Final]
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:951) [:6.1.0.Final]
    at java.lang.Thread.run(Thread.java:662) [:1.6.0_27]