JSF 2.2 + PrettyFaces 3.3.3 + WildFly8

时间:2014-05-09 00:52:40

标签: jsf-2.2 prettyfaces wildfly-8

PrettyFaces对我不起作用。我正在尝试使用简单的方式,使用JSF 2.2,Servlet 3.1,PrettyFaces 3.3.3和WildFly8。我的项目设置如下所示:

Maven依赖项工件:

<dependency>
        <groupId>com.ocpsoft</groupId>
        <artifactId>prettyfaces-jsf2</artifactId>
        <version>3.3.3</version>
</dependency>

web.xml文件的内容:

<?xml version="1.0"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">

<context-param>
    <param-name>com.ocpsoft.pretty.DEVELOPMENT</param-name>
    <param-value>true</param-value>
</context-param>

<context-param>
    <param-name>javax.faces.DEFAULT_SUFFIX</param-name>
    <param-value>.xhtml</param-value>
</context-param>

<context-param>
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
    <param-value>client</param-value>
</context-param>

<servlet>
    <servlet-name>FacesServlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
    <servlet-name>FacesServlet</servlet-name>
    <url-pattern>*.xhtml</url-pattern>
</servlet-mapping>

<session-config>
    <session-timeout>15</session-timeout>
</session-config>

</web-app>

查看我的pretty-faces.config文件的内容:

<?xml version="1.0" encoding="UTF-8"?>
<pretty-config xmlns="http://ocpsoft.com/prettyfaces/3.3.3"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://ocpsoft.com/prettyfaces/3.3.3 http://ocpsoft.com/xml/ns/prettyfaces/ocpsoft-pretty-faces-3.3.3.xsd">

<url-mapping id="home">
    <pattern value="/home" />
    <view-id value="/home.xhtml" />
</url-mapping>

当部署到WildFly中时,一切正常,正如您在代码段日志中所看到的那样:

21:42:34,525 INFO  (DeploymentScanner-threads - 2) JBAS015003: Found populis.war in deployment directory. To trigger deployment create a file called populis.war.dodeploy
21:42:34,531 INFO  (MSC service thread 1-4) JBAS015876: Starting deployment of "populis.war" (runtime-name: "populis.war")
21:42:34,665 INFO  (MSC service thread 1-5) JBAS016002: Processing weld deployment populis.war
21:42:34,691 INFO  (MSC service thread 1-5) JBAS016005: Starting Services for CDI deployment: populis.war
21:42:34,705 INFO  (MSC service thread 1-6) JBAS016008: Starting weld service for deployment populis.war
21:42:34,993 INFO  (MSC service thread 1-1) Initializing Mojarra 2.2.5-jbossorg-3 20140128-1641 for context '/populis'
21:42:35,206 INFO  (MSC service thread 1-1) JBAS017534: Registered web context: /populis
21:42:35,218 INFO  (DeploymentScanner-threads - 1) JBAS018559: Deployed "populis.war" (runtime-name : "populis.war")
21:43:21,412 INFO  (default task-11) PrettyFilter starting up...
21:43:21,452 INFO  (default task-11) PrettyFilter initialized.

但是当我尝试访问我的页面的URL时,我找不到消息,并且日志上没有显示错误消息。任何人都知道我做错了什么? 我遵循get staterd文档(http://ocpsoft.org/docs/prettyfaces/3.3.3/en-US/html/GettingStarted.html)。

问候。

1 个答案:

答案 0 :(得分:1)

您提供的示例应用中存在两个问题。

首先,您的配置文件名称不正确。您将配置文件命名为pretty-faces.xml。正确的名称是pretty-config.xml。所以问题是PrettyFaces找不到你的文件,因此规则不起作用。

第二个问题是您使用了错误的view-id。它必须是这样的:

<url-mapping id="home">
    <pattern value="/home" />
    <view-id value="/home.jsf" />     <!-- note the .jsf here -->
</url-mapping>

我希望这会有所帮助。 :)