SSM登陆验证之过滤器实现

开发中登陆验证是必不可少的,这里介绍过滤器实现的登陆验证。

第一步:创建一个过滤器

package com.test.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;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
 
public class LoginFilter implements Filter{
    
    private String dispatchUrl = "";
    private String excludeUrl = "";
    
    @Override
    public void destroy() {
        
    }
 
    @Override
    public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
            throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest)arg0;
        HttpServletResponse response =(HttpServletResponse)arg1;
        String servletPath = request.getServletPath();
        
        HttpSession session = request.getSession();
        Object userObj = session.getAttribute("loginUser");
        
        /*登陆界面和登陆方法不进行过滤*/
        if(servletPath.equals(dispatchUrl) || servletPath.equals(excludeUrl)){
            arg2.doFilter(arg0, arg1);
        }else{
            if (userObj != null) {
                arg2.doFilter(arg0, arg1);
            }else{
                response.sendRedirect(request.getContextPath()+dispatchUrl);
            }
        }
    }
 
    @Override
    public void init(FilterConfig arg0) throws ServletException {
        dispatchUrl = arg0.getInitParameter("dispatchUrl");
        excludeUrl = arg0.getInitParameter("excludeUrl");
    }
 
}


第二步:配置web.xml文件(),在springmvc启动配置后加入以下代码

 <!--登陆过滤器 start -->
    <filter>
    <filter-name>loginFilter</filter-name>
    <filter-class>com.test.filter.LoginFilter</filter-class>
        <init-param>
            <!--不进行过滤的url,因为它就是跳转到登陆界面, -->
            <param-name>excludeUrl</param-name>
            <param-value>/login</param-value>
        </init-param>
        <init-param>
            <!--未登录用户跳转的url -->
            <param-name>dispatchUrl</param-name>
        <param-value>/login.jsp</param-value>
    </init-param>
    </filter>
    <filter-mapping>
        <filter-name>loginFilter</filter-name>
    <url-pattern>*.jsp</url-pattern>
    </filter-mapping>
    <!--登陆过滤器end -->


第三步:创建登陆页面login.jsp,路径在WebContent目录下

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="c"%>
<c:set var="ctx" value="${pageContext.request.contextPath}"></c:set>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title></title>
    
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">    
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
  </head>
  <body>
      <form action="${ctx}/login.do" method="post"><br>
          用户名:<input type="text" name="username" id="username" value=""/><br><br>
          密 码:<input type="password" name="password" id="password" value=""/>
          <input type="submit" value="登录">
      </form>
  </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值