JSP使用Servlet过滤器进行身份验证的方法

前端技术 2023/09/06 JSP

本文实例讲述了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程序设计有所帮助。

本文地址:https://www.stayed.cn/item/15102

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。