




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
四个有用的Java过滤器java 代码一、使浏览器不缓存页面的过滤器 package com.sist;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) 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);二、检测用户是否登陆的过滤器package com.sist;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.StringTokenizer;import java.io.IOException;/* * 用于检测用户是否登陆的过滤器,如果未登录,则重定向到指的登录页面 * 配置参数 checkSessionKey 需检查的在 Session 中保存的关键字 * redirectURL 如果用户未登录,则重定向到指定的页面,URL不包括 ContextPath * notCheckURLList不做检查的URL列表,以分号分开,并且 URL 中不包括 ContextPath */public class CheckLoginFilter implements Filter 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 HttpServletRequest request = (HttpServletRequest) servletRequest;HttpServletResponse response = (HttpServletResponse) servletResponse;HttpSession session = request.getSession();if (sessionKey = null) filterChain.doFilter(request, response);return;if (!checkRequestURIIntNotFilterList(request)&session.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 = request.getServletPath()+ (request.getPathInfo() = null ? : request.getPathInfo();return notCheckURLList.contains(uri);public void init(FilterConfig filterConfig) throws ServletException redirectURL = filterConfig.getInitParameter(redirectURL);sessionKey = filterConfig.getInitParameter(checkSessionKey);String notCheckURLListStr = filterConfig.getInitParameter(notCheckURLList);if (notCheckURLListStr != null) StringTokenizer st = new StringTokenizer(notCheckURLListStr, ;);notCheckURLList.clear();while (st.hasMoreTokens() notCheckURLList.add(st.nextToken();三、字符编码的过滤器package com.sist;import javax.servlet.*;import java.io.IOException;/* * 用于设置 HTTP 请求字符编码的过滤器,通过过滤器参数encoding指明使用何种字符编码, * 用于处理Html Form请求参数的中文问题 */public class CharacterEncodingFilter implements Filter protected String encoding = ;public void doFilter(ServletRequest servletRequest,ServletResponse servletResponse, FilterChain filterChain)throws IOException, ServletException if (encoding != null)servletRequest.setCharacterEncoding(encoding);filterChain.doFilter(servletRequest, servletResponse);public void destroy() encoding = null;public void init(FilterConfig filterConfig) throws ServletException this.encoding = filterConfig.getInitParameter(encoding);四、资源保护过滤器 package catalog.view.util; import javax.servlet.Filter; import javax.servlet.FilterConfig; import javax.servlet.ServletRequest; 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.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.restrictedResources = new HashSet(); this.restrictedResources.add(/createProduct.jsf); this.restrictedResources.add(/editProduct.jsf); this.restrictedResources.add(/productList.jsf); /* * Standard doFilter object. */ public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException this.logger.debug(doFilter); String contextPath = (HttpServletRequest)req).getContextPath(); String requestUri = (HttpServletRequest)req).getRequestURI(); this.logger.debug(contextPath = + contextPath); this.logger.debug(requestUri = + requestUri); if (this.contains(requestUri, contextPath) & !this.authorize(HttpServletRequest)req) this.logger.debug(authorization failed); (HttpServletRequest)req).getRequestDispatcher(LOGIN_PAGE_URI).forward(req, res); else this.logger.debug(authorization succeeded); chain.doFilter(req, res); public void destroy() private boolean contains(String value, String contextPath) Iterator ite = this.restrictedResources.iterator(); while (ite.hasNext() String restrictedResource = (String)ite.next(); if (contextPath + restrictedResource).equalsIgnoreCase(value) return true; return false; private boolean authorize(HttpServletRequest req) /处理用户登录 /* UserBean user = (UserBean)req.getSession().getAttribute(BeanNames.USER_BEAN); if (user != null & user.getLoggedIn() /user logged in return true; else return false; */ Servlet过滤器大全 四、资源保护过滤器 package catalog.view.util; import javax.servlet.Filter; import javax.servlet.FilterConfig; import javax.servlet.ServletRequest; 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.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.restrictedResources = new HashSet(); this.restrictedResources.add(/createProduct.jsf); this.restrictedResources.add(/editProduct.jsf); this.restrictedResources.add(/productList.jsf); /* */* * Standard doFilter object. */ public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException this.logger.debug(doFilter); String contextPath = (HttpServletRequest)req).getContextPath(); String requestUri = (HttpServletRequest)req).getRequestURI(); this.logger.debug(contextPath = + contextPath); this.logger.debug(requestUri = + requestUri); if (this.contains(requestUri, contextPath) & !this.authorize(HttpServletRequest)req) this.logger.debug(authorization failed); (HttpServletRequest)req).getRequestDispatcher(LOGIN_PAGE_URI).forward(req, res); else this.logger.debug(authorization succeeded); chain.doFilter(req, res); public void destroy() private boolean contains(String value, String contextPath) Iterator ite = this.restrictedResources.iterator(); while (ite.hasNext() String restrictedResource = (String)ite.next(); if (contextPath + restrictedResource).equalsIgnoreCase(value) return true; return false; private boolean authorize(HttpServletRequest req) /处理用户登录 /*/* UserBean user = (UserBean)req.getSession().getAttribute(BeanNames.USER_BEAN); if (user != null & user.getLoggedIn() /user logged in return true; else return false; */ 五、利用Filter限制用户浏览权限 在一个系统中通常有多个权限的用户。不同权限用户的可以浏览不同的页面。使用Filter进行判断不仅省下了代码量,而且如果要更改的话只需要在Filter文件里动下就可以。 以下是Filter文件代码: import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.http.HttpServletRequest; public class RightFilter implements Filt
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 外派员工安全培训课件
- 2025年全国社会工作者职业水平考试中级《综合能力》试题
- 2025年全国“质量月”全面质量管理知识考试题库(附答案)
- 森林生态修复工程创新创业项目商业计划书
- 管理学基础期末考试试题及答案
- 杏仁去皮处理创新创业项目商业计划书
- 布艺创新创业项目商业计划书
- 小龙虾品牌营销策划创新创业项目商业计划书
- 岗前安全培训总结课件
- 小麦早餐谷物创新创业项目商业计划书
- 厂房搬迁管理办法
- 保险学考试题(附答案)
- 中药处方点评管理办法
- 国企纪法教育实施路径
- 药品发放登记管理制度
- 临床科室科研管理制度
- 铁艺围栏采购合同
- 中国皮肤基底细胞癌诊疗指南2023
- 卫星通信技术在电力行业中的应用场景分析
- 黄旭华人物介绍
- 《医疗机构工作人员廉洁从业九项准则》解读
评论
0/150
提交评论