我在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>
答案 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}/[^/]+
在这种情况下,您的样式表不再符合该模式。