我在JSF应用程序中使用Servlet过滤器。我的应用程序中有三组Web页面,我希望在Servlet筛选器中检查这些页面的身份验证:
我的文件夹
/Admin/ *.xhtml
/Supervisor/*.xhtml
/Employee/*.xhtml
我正在编写web.xml
,就像这样
<filter>
<filter-name>LoginFilter</filter-name>
<filter-class>com.ems.admin.servlet.LoginFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>LoginFilter</filter-name>
<url-pattern>/Employee/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>LoginFilter</filter-name>
<url-pattern>/Admin/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>LoginFilter</filter-name>
<url-pattern>/Supervisor/*</url-pattern>
</filter-mapping>
但是像这样的请求
http://localhost:8080/EMS2/faces/Html/Admin/Upload.xhtml
未进入过滤器。
我必须为这3个文件夹提供安全保护。
如何解决这个问题?
发布于 2012-08-04 23:41:07
如果URL模式以/
开头,那么它是相对于上下文根的。URL模式只匹配http://localhost:8080/EMS2/Admin/*
上的页面(假设/EMS2
是上下文路径),但实际上它们在http://localhost:8080/EMS2/faces/Html/Admin/*
上,所以/Admin/*
模式永远不会匹配。
您还需要在URL模式前加上/faces/Html
前缀,如下所示:
<url-pattern>/faces/Html/Admin/*</url-pattern>
你也可以重新配置你的web项目结构/配置,这样你就可以去掉URL中的/faces/Html
路径,这样你就可以通过例如http://localhost:8080/EMS2/Admin/Upload.xhtml
打开页面了。
您的过滤器映射语法都很好。但是,指定多个<filter-mapping>
模式的一种更简单的方法是只使用一个带有多个<url-pattern>
条目的URL:
<filter-mapping>
<filter-name>LoginFilter</filter-name>
<url-pattern>/faces/Html/Employee/*</url-pattern>
<url-pattern>/faces/Html/Admin/*</url-pattern>
<url-pattern>/faces/Html/Supervisor/*</url-pattern>
</filter-mapping>
发布于 2014-09-18 03:59:41
如果您使用注释方法来定义过滤器(而不是在web.xml
中定义它们),则只需在@WebFilter
注释中放置一个映射数组即可实现:
/**
* Filter implementation class LoginFilter
*/
@WebFilter(urlPatterns = { "/faces/Html/Employee","/faces/Html/Admin", "/faces/Html/Supervisor"})
public class LoginFilter implements Filter {
...
就像一个FYI一样,同样的事情也适用于使用servlet注释的servlet:
/**
* Servlet implementation class LoginServlet
*/
@WebServlet({"/faces/Html/Employee", "/faces/Html/Admin", "/faces/Html/Supervisor"})
public class LoginServlet extends HttpServlet {
...
https://stackoverflow.com/questions/11645516
复制相似问题