1

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>

当 make 部署到 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)。

问候。

4

1 回答 1

1

您提供的示例应用程序中有两个问题。

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

第二个问题是您使用了不正确的视图 ID。它必须是这样的:

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

我希望这有帮助。:)

于 2014-05-19T05:51:37.680 回答