手机
当前位置:查字典教程网 >编程开发 >JSP教程 >JSP使用Servlet过滤器进行身份验证的方法
JSP使用Servlet过滤器进行身份验证的方法
摘要:本文实例讲述了JSP使用Servlet过滤器进行身份验证的方法。分享给大家供大家参考,具体如下:1、Servlet过滤器的作用描述(1)在H...

本文实例讲述了JSP使用Servlet过滤器进行身份验证的方法。分享给大家供大家参考,具体如下:

1、Servlet过滤器的作用描述

(1)在HttpServletRequest到达Servlet 之前,拦截客户的HttpServletRequest。

根据需要检查HttpServletRequest,也可以修改HttpServletRequest头和数据。

(2)在HttpServletResponse 到达客户端之前,拦截HttpServletResponse。

根据需要检查HttpServletResponse,可以修改HttpServletResponse头和数据。

2、应用Servlet过滤器进行身份验证

假设网站根目录下的login1.htm、longin1.jsp用于用户登录,而chap08目录下的文件需要用户登录后才能访问。

(1)编写Servlet过滤器

@WebFilter("/FilterStation") public class FilterStation extends HttpServlet implements Filter { private FilterConfig filterConfig; public FilterStation() { super(); } public void destroy() { } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpSession session=((HttpServletRequest)request).getSession(); response.setCharacterEncoding("gb2312"); if(session.getAttribute("me")==null){ PrintWriter out=response.getWriter(); out.print("<script>alert('请登录!');location.href='../login1.htm'</script>"); } else{ // pass the request along the filter chain chain.doFilter(request, response); } } public void init(FilterConfig fConfig) throws ServletException { // TODO Auto-generated method stub this.filterConfig=fConfig; } }

(2)配置web.xml

<filter> <filter-name>filterstation</filter-name> <filter-class>zhou.FilterStation</filter-class> </filter> <filter-mapping> <filter-name>filterstation</filter-name> <url-pattern>/chap08/*</url-pattern> </filter-mapping>

(3)login1.htm代码

<html> <head> <title>用户登录</title> </head> <body> <form method="POST" action="login1.jsp"> <p>用户名:<input type="text" name="user" size="18"></p> <p>密码:<input type="text" name="pass" size="20"></p> <p><input type="submit" value="提交" name="ok"> <input type="reset" value="重置" name="cancel"></p> </form> </body> </html>

(4)login1.jsp代码

<%@ page contentType="text/html;charset=GB2312" %> <html> <head><title>Session 应用演示</title></head> <% if (request.getParameter("user")!=null && request.getParameter("pass")!=null) { String strName=request.getParameter("user"); String strPass=request.getParameter("pass"); if (strName.equals("admin") && strPass.equals("admin")) { session.setAttribute("login","OK"); session.setAttribute("me",strName); response.sendRedirect("chap08/welcome.jsp"); } else { out.print("<script>alert('用户名或密码错误');location.href='login1.htm'</script>"); } } %> </html>

希望本文所述对大家JSP程序设计有所帮助。

【JSP使用Servlet过滤器进行身份验证的方法】相关文章:

JSP页面缓存cache技术--浏览器缓存介绍及实现方法

两个JSP页面父页面获取子页面内容的两种方法

访问JSP文件或者Servlet文件时提示下载的解决方法

JSP/Servlet 中的汉字编码问题

处理jsp显示文字过长问题的解决方法

JSP代码运行错误的问题及解决方法

java使用smartupload组件实现文件上传的方法

用户登录验证的JSP完整程序

Jsp生成页面验证码的方法[附代码]

jsp中使用jstl导入html乱码问题解决方法

精品推荐
分类导航