- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的应用程序基于带有 Postgres 9.2 DB 的 Glassfish 4 上的 JSF 2.2 EJB 3 JPA。我在 Glassfish 上创建了一个 ConnectionPool 和 Datasource,并通过相关的 Datasource JNDI 名称在我的应用程序中使用它。我有两个 Facelets 页面:
login.xhtml 调用 BackingBean LoginBacking,后者调用 UserManagement EJB 上的登录方法,后者使用 JPA 持久性单元检查登录。在这种情况下,一切正常,用户可以登录,如果电子邮件已经存在,系统会通知用户他已经注册。
registration.xhtml 调用 BackingBean RegistrationBacking,后者调用 UserManagement EJB 上的 register 方法,使用 JPA 持久性单元将用户持久保存到数据库中。注册无效!通过查看 Glassfish 日志,我发现了以下异常:
Finer: client acquired: 553217772
Finer: TX binding to tx mgr, status=STATUS_ACTIVE
Finer: acquire unit of work: 218748741
Finer: begin unit of work flush
Finer: end unit of work flush
Finest: Execute query ReadAllQuery(referenceClass=MomUser sql="SELECT id, classname, company, email, firstname, insertion_date, lastname, password, status, systemuser FROM momuser WHERE (email = ?)")
Finest: Connection acquired from connection pool [read].
Finest: reconnecting to external connection pool
Fine: SELECT id, classname, company, email, firstname, insertion_date, lastname, password, status, systemuser FROM momuser WHERE (email = ?)
bind => [1 parameter bound]
Finest: Connection released to connection pool [read].
Finer: TX beforeCompletion callback, status=STATUS_ACTIVE
Finer: begin unit of work commit
Finer: TX afterCompletion callback, status=COMMITTED
Finer: end unit of work commit
Finer: release unit of work
Finer: client released
Finer: client acquired: 1869986747
Finer: TX binding to tx mgr, status=STATUS_ACTIVE
Finer: acquire unit of work: 76560055
Finer: TX afterCompletion callback, status=ROLLEDBACK
Finer: release unit of work
Finer: client released
Warning: EJB5184:A system exception occurred during an invocation on EJB MomUserManager, method: public void eu.fabrig.mom.session.MomUserManager.registerUser(eu.fabrig.mom.jpa.entity.MomUser) throws eu.fabrig.mom.exception.UserExistsException
Warning: javax.ejb.EJBException
at com.sun.ejb.containers.EJBContainerTransactionManager.processSystemException(EJBContainerTransactionManager.java:748)
at com.sun.ejb.containers.EJBContainerTransactionManager.completeNewTx(EJBContainerTransactionManager.java:698)
...
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544)
at java.lang.Thread.run(Thread.java:744)
Caused by: java.lang.IllegalArgumentException: Object: MomUser{id=null, classname=MOMUser, status=A, systemuser=null, insertionDate=null, email=a@c.it, password=098f6bcd4621d373cade4e832627b4f6, firstname=test, lastname=test, company=Test S.p.A.} is not a known entity type.
at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.registerNewObjectForPersist(UnitOfWorkImpl.java:4222)
...
at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:212)
... 54 more
Severe: javax.ejb.EJBException
at com.sun.ejb.containers.EJBContainerTransactionManager.processSystemException(EJBContainerTransactionManager.java:748)
at com.sun.ejb.containers.EJBContainerTransactionManager.completeNewTx(EJBContainerTransactionManager.java:698)
...
at java.lang.Thread.run(Thread.java:744)
Caused by: java.lang.IllegalArgumentException: Object: MomUser{id=null, classname=MOMUser, status=A, systemuser=null, insertionDate=null, email=a@c.it, password=098f6bcd4621d373cade4e832627b4f6, firstname=test, lastname=test, company=Test S.p.A.} is not a known entity type.
at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.registerNewObjectForPersist(UnitOfWorkImpl.java:4222)
at org.eclipse.persistence.internal.jpa.EntityManagerImpl.persist(EntityManagerImpl.java:496)
...
at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:212)
... 54 more
Info: ### You can do the cleanup here
在我的 persistence.xml 下:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="eu.fabrig_MOM.PU" transaction-type="JTA">
<jta-data-source>myDataSource</jta-data-source>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<!-- <class>eu.fabrig.mom.jpa.entity.MomUser</class> -->
<properties>
<property name="eclipselink.logging.level" value="FINEST"/>
</properties>
</persistence-unit>
</persistence>
我的实体和托管 Bean 类:
@Entity
@Table(name = "momuser")
@Named
@RequestScoped
@XmlRootElement
public class MomUser implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "user_seq_gen")
@SequenceGenerator(name = "user_seq_gen", sequenceName = "mom_seq_id")
@Basic(optional = false)
@Column(name = "id")
private Integer id;
@Basic(optional = false)
@Size(min = 1, max = 100)
@Column(name = "classname")
private String classname = "MOMUser";
@Column(name = "status")
private Character status = 'A';
@Size(max = 100)
@Column(name = "systemuser")
private String systemuser;
@Basic(optional = false)
@Column(name = "insertion_date", insertable = false, updatable = false)
@Temporal(TemporalType.TIMESTAMP)
private Date insertionDate;
@Basic(optional = false)
@NotNull
@Size(min = 1, max = 255)
@Column(name = "email")
private String email;
@Basic(optional = false)
@NotNull
@Size(min = 1, max = 255)
@Column(name = "password")
private String password;
@Basic(optional = false)
@NotNull
@Size(min = 1, max = 255)
@Column(name = "firstname")
private String firstname;
@Basic(optional = false)
@NotNull
@Size(min = 1, max = 255)
@Column(name = "lastname")
private String lastname;
@Size(max = 100)
@Column(name = "company")
private String company;
...
// Getters and Setters
在 EJB 方法下面:
@Override
public void registerUser(MomUser user) throws UserExistsException {
try {
user.setPassword(generateMD5Hash(user.getPassword()));
em.persist(user);
} catch (UnsupportedEncodingException | NoSuchAlgorithmException ex) {
Logger.getLogger(MomUserManager.class.getName()).log(Level.SEVERE, null, ex);
}
}
Backing bean 方法:
public String register(){
try {
MomUser currentMomUser = (MomUser) evaluateEL("#{momUser}", MomUser.class);
MomUser momUser = userManager.getUser(currentMomUser.getEmail());
if (momUser != null) {
getContext().addMessage(null, new FacesMessage(EMAIL_ALREADY_EXISTS));
return null;
}
try {
userManager.registerUser(currentMomUser);
} catch (UserExistsException ex) {
Logger.getLogger(RegistrationBacking.class.getName()).log(Level.SEVERE, null, ex);
getContext().addMessage(null, new FacesMessage(EMAIL_ALREADY_EXISTS));
return null;
}
} catch (Exception ex) {
Logger.getLogger(RegistrationBacking.class.getName()).log(Level.SEVERE, null, ex);
getContext().addMessage(null, new FacesMessage(SYSTEM_ERROR));
return null;
}
return "login";
}
以及注册Facelet:
<f:facet name="header">
<h:outputText value="#{bundle['application.registerpage.registrationMessage']}"/>
</f:facet>
<h:outputText value="#{bundle['momuser.email']}"/><h:inputText id="email"
value="#{momUser.email}"
required="true"
requiredMessage="#{bundle['momuser.email.validation']}"
validatorMessage="#{bundle['momuser.email.invalid']}">
<f:validateRegex pattern="[\w\.-]*[a-zA-Z0-9_]@[\w\.-]*[a-zA-Z0-9]\.[a-zA-Z][a-zA-Z\.]*[a-zA-Z]"/>
</h:inputText>
<h:message for="email" styleClass="errorMessage"/>
<h:outputText value="#{bundle['momuser.password']}"/>
<h:inputSecret id="password"
value="#{momUser.password}"
required="true"
requiredMessage="#{bundle['momuser.password.validation']}"></h:inputSecret>
<h:message for="password" styleClass="errorMessage"/>
<h:outputText value="#{bundle['momuser.firstname']}"/>
<h:inputText id="firstname"
value="#{momUser.firstname}"
required="true"
requiredMessage="#{bundle['momuser.firstname.validation']}"/>
<h:message for="firstname" styleClass="errorMessage"/>
<h:outputText value="#{bundle['momuser.lastname']}"/>
<h:inputText id="lastname"
value="#{momUser.lastname}"
required="true"
requiredMessage="#{bundle['momuser.lastname.validation']}"/>
<h:message for="lastname" styleClass="errorMessage"/>
<h:outputText value="#{bundle['momuser.company']}"/>
<h:inputText id="company"
value="#{momUser.company}"
required="false"/>
<h:message for="company" styleClass="errorMessage"/>
<f:facet name="footer">
<h:panelGroup style="display:block; text-align:center">
<h:commandButton value="#{bundle['application.registrationpage.proceed']}" action="/registration/registrationconfirm?faces-redirect=true"/>
<h:commandButton value="Register" action="#{registrationBacking.register}"/>
<h:link value="#{bundle['application.registrationpage.gotologin']}" outcome="/login"/>
<h:messages globalOnly="true" styleClass="errorMessage"/>
</h:panelGroup>
</f:facet>
</h:panelGrid>
</h:form>
你有什么想法吗?为什么我可以登录但无法注册新用户?
谢谢
最佳答案
感谢@unwichtich 的回答,但我终于找到了问题所在,这是我疏忽造成的!我导入了错误的@SessionScope,它带有 JSF 上下文 (javax.faces.bean.SessionScoped),而不是带有企业上下文 (javax.enterprise.context.SessionScoped) 的。现在可以注册了!
关于postgresql - Glassfish 4 和 Postgres ConnectionPool 上的 JSF 2.2 + EJB 3 + JPA,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23948920/
我需要审核 ejb bean 的调用。说审计我的意思是将当前登录的用户、方法名称、附加描述等信息写入数据库。我决定使用 CDI 装饰器来做到这一点: @Decorator public class A
当我使用 EJB 3.0 部署 Web 应用程序时,我看到了以下警告: WARNING: jar 'E:\mws\MCDS\portal\portal-web\target\portal-web-1.
我正在学习 EJB,当尝试使用 junit 测试它时,出现以下错误 cd.espoirmur.Ejb.InterfaceEjbLocal_80488159 Jun 03, 2016 10:33:58
是否可以在另一个 EJB 中使用 @EJB?我现在正在尝试这样做,但我的 EJB 最终为空。我将在示例中概述我的问题。 @Stateless @LocalBean @Local(LoginServic
我已通读 article试图理解为什么要在客户端和实体 bean 之间有一个 session bean。是不是因为让客户端直接访问实体bean,就让客户端对数据库一清二楚了? 因此,通过使用中间人(
我们正在尝试在具有两个节点的以域模式运行的 Wildfly 中查找远程 EJB。 设置是这样的: Wildfly 节点 1: 模块 A:EJB 客户端 模块 B:远程 EJB Wildfly 节点 2
我正在使用 Jboss 7,并且有两个单独的部署,它们都包含单例 EJB。 我需要一个 EJB 才能访问另一个 EJB 并能够调用其方法,但是,当应用程序服务器启动并尝试部署它们时,它似乎无法保证哪个
可能最好的方法是手动完成。但是在大型项目中,您需要一些工具来帮助您。正是这个想法促使我搜索了一个工具。 是否有任何 EJB 迁移工具可用于将 EJB 2.0 迁移到 3.x。 最佳答案 它的开发时间很
I am migrating Ejb 2.1 to Ejb 3.1. I changed Java Version from 1.6 to 1.8, and Ejb Version from 2.1
我已经使用 @ActivationConfigProperty 配置了消息目标类型、名称等。在 EJB 3.0 中,但我想配置 MDB使用部署描述符 ( ejb-jar.xml ),就像在 EJB 2
假设我有两个 EJB jar:A.jar 和 B.jar。我可以使用 CDI 将不是 EJB 的实用程序类 Autil 注入(inject) A.jar 中的 POJO 到 B.jar 中的 EJB
我有一个需要配置不同的现有项目。这需要在没有重大代码更改的情况下发生。我实际上希望我只能通过配置以某种方式做到这一点。在过去的 2 到 3 天里,我一直在阅读我能找到的关于这个问题的所有内容。我了解
我有一个非常简单的带有maven的ejb 3.0模块,它只有两个 session bean,一个是无状态的,另一个是单例的...当我尝试在Glassfish 3.0服务器上部署该项目时,我得到了这个异
我们在微服务中看到的是一个孤立的组件,通过协议(protocol)通过网络与该组件的父消费者进行通信。 我们在 EJB 1.0 中看到了非常相似的模式。 我的问题是:微服务架构模式是否类似于 EJB
我在 Java EE6 Singleton Session Bean 中有一个方法,它每 30 秒由 @Schedule(...) 计时器调用。这按预期工作,直到在方法中抛出并捕获异常(异常在 try
我正在 JDeveloper 11.1.1.4 中开发一个 JAX-WS WebService,它应该使用之前部署到 WebLogic 服务器的 JAR 中的 EJB。 WebService项目和EJ
我正在尝试使用 JAX-RS 注释将一些 EJB 公开为 REST Web 服务。当我部署 war WEB-INF/lib 中包含 EJB Jar 的文件到 Wildfly 8,我可以在 Web 管理
我是 EJB 方面的新手,但我已经获得了 EJB 级别的提升。 该层由一个 EJB 组成,它公开可用的操作: @Stateless(name = "myejb") public class Facad
假设我想创建一个我将在未来项目中使用的库,但我还想在该库中包含引用其他 EJB 等的 EJB。该库还将包含简单的 Java 类。最好的方法是什么?在这种情况下如何定义依赖关系?我想我会用注释来定义它们
我想知道是否可以按照这些思路做一些事情: 1)服务器端(EJB类) @Statefull public class SomeEJB implements SomeEJBRemote { @Resour
我是一名优秀的程序员,十分优秀!