/**
* 过滤器的使用:
* 作用:
* 对服务器端接受的请求资源和响应给浏览器的资源进行管理
* 调用:
* 服务器调用,通过配置web.xml
* 保护servlet
* 使用:
* 创建一个实现了Filter接口的普通Java类
* 覆写接口的方法
* init方法:服务器启动执行。资源初始化
* doFilter方法:拦截请求的方法,在此方法中可以对资源实现管理。
* 注意:
* 需要手动对请求进行放行:chain.doFilter(request, response);
* destroy方法:服务器关闭执行。
* 在web.xml中配置过滤器
* <!-- 配置过滤器 过滤所有请求包括jsp-->
* <filter>
* <filter-name>myFilter</filter-name>
* <filter-class>com.sxt.filter.MyFilter</filter-class>
* </filter>
* <filter-mapping>
* <filter-name>myFilter</filter-name>
* <url-pattern>/*</url-pattern>
* 注意:(服务器调用顺序与其在web.xml在声明的顺序相关)
* url-pattern:/* --->拦截所有请求
* *.do --->拦截所有以.do结尾的请求。一般用来进行模块拦截处理
* ts.do --->拦截已ts.do的请求。拦截指定url的请求。
* 针对某个servlet进行拦截,保护servlet
* 过滤器生命周期:
* 服务器启动到服务器关闭。
* 总结:
* 过滤器由程序员声明和配置,服务器根据请求中的uri信息进行调用。
* 执行:
* 浏览器发起请求到服务器,服务器接受到请求后,根据uri信息在web.xml中找到对应的过滤器,执行doFilter方法,
* 该方法对请求进行处理后,如果符合要求,则放行。放行后,如果还有符合要求的过滤器则继续进行过滤,直到执行对应的
* servlet进行请求处理。servlet对请求处理完成后,也就是service方法结束后,继续返回相应的doFilter方法继续执行。
* 案例:(doFilter的作用)
* 统一编码格式
* session管理(判断session是否失效,只需要该处判断一次:若失效则重定向用户重新登录,避免在后续每个servlet中判断session是否失效等等)
* 权限管理
* 资源管理(统一给加水印、和谐词汇等等)
*
*/
public class MyFilter implements Filter{
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("MyFilter.init(我被初始化了)");
}
@Override
public void destroy() {
System.out.println("MyFilter.destroy(我被销毁了)");
}
@Override
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("MyFilter.doFilter(我被执行了)");
//设置请求编码格式
request.setCharacterEncoding("utf-8");
//设置响应编码格式
response.setContentType("text/html;charset=utf-8");
//判断session
HttpSession hs=((HttpServletRequest)request).getSession();
if(hs.getAttribute("user")==null){
((HttpServletResponse)response).sendRedirect("/a/login.jsp");
}else{
//放行
chain.doFilter(request, response);
}
System.out.println("MyFilter.doFilter(我被执行了2)");
}
}