java五个有用的过滤器

上传人:第*** 文档编号:34039770 上传时间:2018-02-20 格式:DOCX 页数:8 大小:19KB
返回 下载 相关 举报
java五个有用的过滤器_第1页
第1页 / 共8页
java五个有用的过滤器_第2页
第2页 / 共8页
java五个有用的过滤器_第3页
第3页 / 共8页
java五个有用的过滤器_第4页
第4页 / 共8页
java五个有用的过滤器_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《java五个有用的过滤器》由会员分享,可在线阅读,更多相关《java五个有用的过滤器(8页珍藏版)》请在金锄头文库上搜索。

1、五个有用的过滤器一、 使浏览器不缓存页面的过滤器import javax.servlet.*; import javax.servlet.http.HttpServletResponse; import java.io.IOException; /* * 用于的使 Browser 不缓存页面的过滤器 */ public class ForceNoCacheFilter implements Filter public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain)

2、throws IOException, ServletException (HttpServletResponse) response).setHeader(Cache-Control,no-cache); (HttpServletResponse) response).setHeader(Pragma,no-cache); (HttpServletResponse) response).setDateHeader (Expires, -1); filterChain.doFilter(request, response); public void destroy() public void

3、init(FilterConfig filterConfig) throws ServletException 二、检测用户是否登陆的过滤器 import javax.servlet.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.util.List; import java.util.ArrayList; import java.util.Strin

4、gTokenizer; import java.io.IOException; /* * 用于检测用户是否登陆的过滤器,如果未登录,则重定向到指的登录页面 * 配置参数 * checkSessionKey 需检查的在 Session 中保存的关键字 * redirectURL 如果用户未登录,则重定向到指定的页面,URL 不包括 ContextPath * notCheckURLList 不做检查的 URL 列表,以分号分开,并且 URL 中不包括 ContextPath */ public class CheckLoginFilter implements Filter protected

5、FilterConfig filterConfig = null; private String redirectURL = null; private List notCheckURLList = new ArrayList(); private String sessionKey = null; public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException Ht

6、tpServletRequest request = (HttpServletRequest) servletRequest; HttpServletResponse response = (HttpServletResponse) servletResponse; HttpSession session = request.getSession(); if(sessionKey = null) filterChain.doFilter(request, response); return; if(!checkRequestURIIntNotFilterList(request) & sess

7、ion.getAttribute(sessionKey) = null) response.sendRedirect(request.getContextPath() + redirectURL); return; filterChain.doFilter(servletRequest, servletResponse); public void destroy() notCheckURLList.clear(); private boolean checkRequestURIIntNotFilterList(HttpServletRequest request) String uri = r

8、equest.getServletPath() + (request.getPathInfo() = null ? : request.getPathInfo(); return notCheckURLList.contains(uri); public void init(FilterConfig filterConfig) throws ServletException this.filterConfig = filterConfig; redirectURL = filterConfig.getInitParameter(redirectURL); sessionKey = filter

9、Config.getInitParameter(checkSessionKey); String notCheckURLListStr = filterConfig.getInitParameter(notCheckURLList); if(notCheckURLListStr != null) StringTokenizer st = new StringTokenizer(notCheckURLListStr, ;); notCheckURLList.clear(); while(st.hasMoreTokens() notCheckURLList.add(st.nextToken();

10、三、字符编码的过滤器 import javax.servlet.*; import java.io.IOException; /* * 用于设置 HTTP 请求字符编码的过滤器,通过过滤器参数 encoding 指明使用何种字符编码,用于处理 Html Form 请求参数的中文问题 */ public class CharacterEncodingFilter implements Filter protected FilterConfig filterConfig = null; protected String encoding = ; public void doFilter(Servl

11、etRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException if(encoding != null) servletRequest.setCharacterEncoding(encoding); filterChain.doFilter(servletRequest, servletResponse); public void destroy() filterConfig = null; encoding = nu

12、ll; public void init(FilterConfig filterConfig) throws ServletException this.filterConfig = filterConfig; this.encoding = filterConfig.getInitParameter(encoding); 四、资源保护过滤器 package catalog.view.util; import javax.servlet.Filter; import javax.servlet.FilterConfig; import javax.servlet.ServletRequest;

13、 import javax.servlet.ServletResponse; import javax.servlet.FilterChain; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import java.io.IOException; import java.util.Iterator; import java.util.Set; import java.util.HashSet; / import mons.logging.Log; import mons.

14、logging.LogFactory; /* * This Filter class handle the security of the application. * * It should be configured inside the web.xml. * * author Derek Y. Shen */ public class SecurityFilter implements Filter /the login page uri private static final String LOGIN_PAGE_URI = login.jsf; /the logger object private Log logger = LogFactory.getLog(this.getClass(); /a set of restricted resources private Set restrictedResources; /* * Initializes the Filter. */ public void init(FilterConfig filterConfig) throws ServletException this.restrictedReso

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 解决方案

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号