无论如何,我愿意尝试一下,然后开始。 如果您想开始使用任何JBoss技术,最好先检查一下JBoss Developer Framework 。 这是各种示例和快速入门的不错集合,可帮助您开始使用Java EE及其技术。 RichFaces-Validation示例就是其中之一,该示例演示了如何一起使用JSF 2.0,RichFaces 4.2,CDI 1.0,JPA 2.0和Bean Validation 1.0。
这个例子
该示例由一个成员实体组成,该成员实体具有一些JSR-303(Bean验证)约束。 通常,从数据库开始,在持久性层,最后是与客户端紧密交互的视图层中的多个地方,对这些位置进行检查。 即使此快速指南不包含持久层,它也从Enity开始,它很好地反映了现实生活中的情况。 该应用程序包含使用JSF和RichFaces编写的视图层,并包括用于新成员注册的AJAX向导。 新注册的成员需要在实际“注册”之前提供一些信息。 这包括通过电子邮件发送姓名和电话号码。
入门
我将不再重复出色而详细的快速入门已经向您展示的内容。 因此,如果您想在JBoss AS7上运行它,请去那里。 我们从一个空白的Maven Web项目开始。 最好,最简单的方法是启动NetBeans 7.2并创建一个。 让我们将其命名为“ richwls-web”。 打开您的pom.xml并开始在那里进行一些更改。 首先在此处删除认可的内容。 我们不需要它。 接下来是添加一点dependencyManagement:
<dependencyManagement><dependencies><dependency><groupId>org.jboss.bom</groupId><artifactId>jboss-javaee-6.0-with-tools</artifactId><version>1.0.0.Final</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>org.richfaces</groupId><artifactId>richfaces-bom</artifactId><version>4.2.0.Final</version><scope>import</scope><type>pom</type></dependency></dependencies></dependencyManagement>
这会将Java EE 6和RichFaces的物料清单(BOM)添加到您的项目中。 BOM会指定工件“堆栈”(或集合)的版本。 您可以从RedHat家伙那里找到任何东西,并且认为拥有它是“最佳实践”。 最后,这可以简化您的工作,因为它可以为您管理版本和依赖项。
关于冗长的真实依赖项列表:
<!-- Import the CDI API --><dependency><groupId>javax.enterprise</groupId><artifactId>cdi-api</artifactId><scope>provided</scope></dependency><!-- Import the JPA API --><dependency><groupId>javax.persistence</groupId><artifactId>persistence-api</artifactId><version>1.0.2</version><scope>provided</scope></dependency><!-- JSR-303 (Bean Validation) Implementation --><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-validator</artifactId><version>4.3.0.Final</version><scope>provided</scope><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId></exclusion></exclusions></dependency><!-- Import the JSF API --><dependency><groupId>javax.faces</groupId><artifactId>jsf-api</artifactId><version>2.1</version><scope>provided</scope></dependency><!-- Import RichFaces runtime dependencies - these will be includedas libraries in the WAR --><dependency><groupId>org.richfaces.ui</groupId><artifactId>richfaces-components-ui</artifactId></dependency><dependency><groupId>org.richfaces.core</groupId><artifactId>richfaces-core-impl</artifactId></dependency>
除了RichFaces依赖项之外,其他所有项都由运行时提供。 在这种情况下,它将是GlassFish 3.1.2.2。 如果您尚未在其他地方(settings.xml)定义它,则还应该将JBoss存储库添加到构建部分:
<repository><id>jboss-public-repository-group</id><name>JBoss Public Maven Repository Group</name><url>https://repository.jboss.org/nexus/content/groups/public-jboss/</url></repository>
复制source-zip的richfaces-validation目录的内容,或从github中检出它 。 请多加注意,不要弄乱我们创建的pom.xml;)构建它并部署这些东西。
问题
首先,您会得到一个很好的焊接信息:
WELD-000054 Producers cannot produce non-serializable instances for injection into non-transient fields of passivating beans [...] Producer Method [Logger] with qualifiers
显然我们这里有一个问题,需要将Logger字段声明为瞬态。
@Inject
private transient Logger logger;
不知道为什么它可以在AS7上工作,但是有一天我可能会发现它是:)下一次迭代:更改,构建,部署。
java.lang.NoSuchMethodError: com.google.common.collect.ImmutableSet.copyOf(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
看起来还不错。 在http:// localhost:7001 / wls-cat /上启动WLS CAT,然后尝试查找它。
似乎Oracle正在服务器内部使用Google Magic。 好的。 我们无法将RichFaces部署为对WebLogic的独立战争,因为我们需要在此处解决一些类加载问题。 推荐的方法是添加一个所谓的过滤类加载器。 您可以通过将weblogic-application.xml添加到您的耳朵来实现。 是的:让我们重新打包所有内容,将战争放在空旷的耳朵中,然后将魔术添加到weblogic-application.xml中:
<prefer-application-packages><package-name>com.google.common.*</package-name></prefer-application-packages>
做完了吗 进行另一次部署,您终于可以看到您的应用程序。 RichFaces基本上是在WebLogic上运行的,但是您必须将其打包到耳朵中,并为com.google.common。*类打开类加载器。 使用PrimeFaces可以轻松得多,但是…无论如何,有一些原因让我尝试这样做。 一种是,我很喜欢能够在客户端触发Bean验证的想法。 如果看一下示例, <rich:validator event ='blur'/>会为客户端添加针对bean验证约束和标准jsf验证器的客户端验证。 无需弄乱JavaScript或重复逻辑中的任何内容。
祝您编程愉快,别忘了分享!
参考:来自JCG合作伙伴 Markus Eisele的WebLogic 12c上的RichFaces运行在 Java软件企业博客上。
翻译自: https://www.javacodegeeks.com/2012/09/running-richfaces-on-weblogic-12c.html