1

我在 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
4

1 回答 1

2

正如 BalusC 所提到的,问题是 apache 将内容类型设置为application/xhtml+xml并且应该是text/css. xml 类型已设置,因为 apache 中的 mod_mime 模块已打开。最简单的解决方案是删除 xhtml 的文件扩展名和内容类型之间的映射。这可以通过添加:

RemoveType xhtml

apache配置中的行。

更多解决方案可以在这里找到:https ://serverfault.com/questions/544723/how-to-set-different-mod-mime-rules-for-reverse-proxy

于 2015-10-21T09:19:58.383 回答