我在 JSF2 中有应用程序(使用 Primefaces)。我使用 将 url 解析为资源h:outputStylesheet
,因此指向我的 css 的链接如下所示:
/project/javax.faces.resource/style.css.xhtml?ln=css
当我在服务器上的 tomcat 上部署项目时,一切正常。当我将 url 放入浏览器时,我可以看到我的 css 文件:
http://myserver.com:8080/project/javax.faces.resource/style.css.xhtml?ln=css
当然,我也可以使用直接 url 访问它来访问资源,例如:
http://myserver.com:8080/project/resources/css/style.css
当我将 apache 配置为将端口 80 上的请求转发到 tomcat 时,问题就开始了。我尝试了两种方法:
- ajp 与 mod_jk
- ajp 与 mod_proxy
两种配置在作为 jsf 资源访问时都会生成无效的 css 文件。当我放:
http://myserver.com/project/javax.faces.resource/style.css.xhtml?ln=css
我收到以下错误消息:
This page contains the following errors:
error on line 1 at column 1: Document is empty
Below is a rendering of the page up to the first error.
但是,我的 css 文件的直接 url 仍然有效:
http://myserver.com/project/resources/css/style.css
我的问题是:我在 ajp 配置中错过了什么?
这是配置:
ajp 工人:
worker.list=ajp13_worker
worker.ajp13_worker.port=8009
worker.ajp13_worker.host=localhost
worker.ajp13_worker.type=ajp13
使用 JK 的 ajp 连接:
JkMount /project/ ajp13_worker
JkMount /project ajp13_worker
JkMount /project/* ajp13_worker
使用代理的替代 ajp 连接:
ProxyPass /project/ ajp://127.0.0.1:8009/project/
ProxyPassReverse /project/ http://127.0.0.1:80/project/
Tomcat服务器.xml
<Connector port="8009" enableLookups="false" protocol="AJP/1.3" redirectPort="8443" />
我用:
- 雄猫 7
- 爪哇 8
- Primefaces 4.0