我有一些如下的Facelets文件。
网页内容
|-index.xhtml
|-register.xhtml
|-模板
| | --userForm.xhtml
| `--banner.xhtml
:
两个页面都使用/templates
目录中的模板。我的/index.xhtml
在浏览器中可以正常打开。我得到了生成的HTML输出。我在/index.xhtml
文件中有一个链接到/register.xhtml
文件。
但是,我的/register.xhtml
没有得到解析,并以纯XHTML /原始XML而不是其生成的HTML输出形式返回。所有#{...}
形式的EL表达式均按原样显示,而不是打印其结果。当我右键单击浏览器中的页面并执行“查看页面源代码”时,仍然可以看到原始的XHTML源代码,而不是生成的HTML输出。例如,<h:body>
没有成为<body>
。看起来模板没有被执行。
但是,当我在浏览器的地址栏中打开/register.xhtml
之类的/faces/register.xhtml
时,它会正确显示。这是怎么引起的,我该如何解决?
请您参考如下方法:
有三个主要原因。FacesServlet
不被调用。
XML名称空间URI丢失或错误。
多个JSF实现已加载。
1.确保URL匹配FacesServlet
映射
链接的URL(在浏览器的地址栏中看到的URL)必须与<url-pattern>
的FacesServlet
的web.xml
相匹配,以使所有JSF作品都能运行。 FacesServlet
是负责解析XHTML文件,收集提交的表单值,执行转换/验证,更新模型,调用操作以及生成HTML输出的程序。如果您不通过URL调用FacesServlet
,那么您将获得的所有内容(并通过右键单击在浏览器中查看源代码来查看)确实是原始的XHTML源代码。
如果<url-pattern>
例如是*.jsf
,则链接应指向/register.jsf
,而不是/register.xhtml
。如果像您一样,例如/faces/*
,则链接应指向/faces/register.xhtml
,而不是/register.xhtml
。避免这种混乱的一种方法是将<url-pattern>
从/faces/*
更改为*.xhtml
。因此,以下是理想的映射:
<servlet>
<servlet-name>facesServlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>facesServlet</servlet-name>
<url-pattern>*.xhtml</url-pattern>
</servlet-mapping>
如果由于某种原因无法将
<url-pattern>
更改为
*.xhtml
,那么您可能还希望阻止最终用户通过URL直接访问XHTML源代码文件。在这种情况下,您可以在
<security-constraint>
的
<url-pattern>
上添加一个
*.xhtml
,并在
<auth-constraint>
中添加一个空的
web.xml
,以防止出现以下情况:
<security-constraint>
<display-name>Restrict direct access to XHTML files</display-name>
<web-resource-collection>
<web-resource-name>XHTML files</web-resource-name>
<url-pattern>*.xhtml</url-pattern>
</web-resource-collection>
<auth-constraint />
</security-constraint>
2017年4月发布的JSF 2.3已通过在webapp启动期间在
FacesServlet
的URL模式下自动注册
*.xhtml
来解决上述所有问题。因此,替代方法是简单地升级到最新可用的JSF版本,该版本应为JSF 2.3或更高版本。但是理想情况下,您仍然应该仅在
FacesServlet
的一个URL模式上显式注册
*.xhtml
,因为对于完全相同的资源(例如
/register.xhtml
,
/register.jsf
,
/register.faces
和
/faces/register.xhtml
)拥有多个可能的URL对SEO不利。 。
也可以看看:
Set default home page via <welcome-file> in JSF project
Opening Facelets page errors with "This XML file does not appear to have any style information associated with it."
Sometimes I see JSF URL is *.jsf, sometimes *.xhtml and sometimes /faces/*. Why?
JavaServer Faces 2.2 and HTML5 support, why is XHTML still being used
Which XHTML files do I need to put in /WEB-INF and which not?
Our servlets wiki-了解有关Servlet的强制性基础知识
2.确保XML名称空间与JSF版本匹配
自从JSF 2.2引入以来,另一个可能的原因是XML名称空间与JSF版本不匹配。如下所示的
xmlns.jcp.org
是JSF 2.2以来的新功能,在旧版JSF中不起作用。症状几乎与未调用
FacesServlet
相同。
<html lang="en"
xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://xmlns.jcp.org/jsf/core"
xmlns:h="http://xmlns.jcp.org/jsf/html"
xmlns:ui="http://xmlns.jcp.org/jsf/facelets">
如果无法升级到JSF 2.2或更高版本,则需要使用旧的
java.sun.com
XML名称空间:
<html lang="en"
xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:ui="http://java.sun.com/jsf/facelets">
但理想情况下,应始终使用可用的最新版本。
也可以看看:
Which XML namespace to use with JSF 2.2 and up
JSF tags not executed
Warning: This page calls for XML namespace http://xmlns.jcp.org/jsf/XXX declared with prefix XXX but no taglibrary exists for that namespace
3.已经加载了多个JSF实现
另一个可能的原因是您的Web应用程序已加载多个JSF实现,彼此冲突和破坏。例如,当您的Web应用程序的运行时类路径被多个不同版本的JSF库污染,或者在特定的Mojarra 2.x + Tomcat 8.x组合中被污染时,当Web应用程序的
ConfigureListener
中有不必要的
web.xml
条目导致其被加载时两次。
<!-- You MUST remove this one from web.xml! -->
<!-- This is actually a workaround for buggy GlassFish3 and Jetty servers. -->
<!-- When leaving this in and you're targeting Tomcat, you'll run into trouble. -->
<listener>
<listener-class>com.sun.faces.config.ConfigureListener</listener-class>
</listener>
使用Maven时,请绝对确保以正确的方式声明依赖关系,并了解依赖关系范围。重要的是,当目标服务器已经提供依赖时,请不要在webapp中捆绑它们。
也可以看看:
Configuration of com.sun.faces.config.ConfigureListener
How to properly install and configure JSF libraries via Maven?
确保您以正确的方式学习JSF
对于不熟悉基本 HTTP, HTML和 Servlets的人,JSF的学习曲线非常陡峭。 Internet上有很多低质量的资源。请忽略由业余人员维护的代码片段抓取站点,这些站点主要关注广告收入而不是教学,例如roseindia,tutorialspoint,javabeat等。通过扰乱广告链接/横幅很容易识别它们。另外,请忽略处理侏罗纪JSF 1.x的资源。通过使用JSP文件而不是XHTML文件,可以轻松识别它们。自2009年JSF 2.0以来,已不推荐使用JSP作为视图技术。
要以正确的方式入门,请从 our JSF wiki page开始并订购 authoritative book。
也可以看看:
Java EE web development, where do I start and what skills do I need?
What is the need of JSF, when UI can be achieved with JavaScript libraries such as jQuery and AngularJS