漂亮的URL使用PrettyFaces隐藏资源

时间:2017-03-08 15:31:24

标签: jsf resources prettyfaces

我在PrettyFaces 3.3.3和Wildfly 10.1.0.Final上运行了一个webapp。为了使URL更加用户友好,我使用了PrettyFaces。有效URL的示例类似于:

http://www.example.com/en/drinks

在这种情况下,bean中会有两个变量:

private String language;
private String zone;

拥有值:

language = "en"
zone = "drinks"

问题是我还有一个带有路径的CSS文件:

http://www.example.com/styles/style.css

PrettyFaces错误地解释了这一点,阻止我访问真实资源:

language = "styles"
zone = "style.css"

我试图找到一种方法告诉PrettyFaces不要翻译CSS文件的URL,但我找不到类似的东西。

有没有办法通过保留漂亮的URL来访问CSS文件?

我目前的PrettyFaces配置是:

<url-mapping id="zoneSelected"> 
    <pattern value="/#{navigationController.language}/#{navigationController.zone}" /> 
    <view-id>/faces/index.xhtml</view-id>
</url-mapping>

1 个答案:

答案 0 :(得分:2)

PrettyFaces将匹配正则表达式的任何传入请求。

这样的模式:

<pattern value="/#{bean.language}/#{bean.zone}" />

将转换为这样的正则表达式:

/[^/]+/[^/]+

这是因为默认情况下,PrettyFaces会对所有路径参数使用[^/]+

这样的一般模式也会与CSS或图像文件等其他资源相匹配。

解决此问题的一种方法是自定义PrettyFaces将用于path参数的正则表达式模式。这很容易做到并在这里描述:

http://www.ocpsoft.org/docs/prettyfaces/3.3.3/en-US/html/Configuration.html#config.pathparams.regex

所以基本上只是使用这种模式:

<pattern value="/#{ /[a-z]{2}/ bean.language }/#{bean.zone}" />

这将转换为:

/[a-z]{2}/[^/]+

在这种情况下,您的样式表不再符合该模式。