1. 程式人生 > 程式設計 >使用Filter實現登入許可權驗證

使用Filter實現登入許可權驗證

本文例項為大家分享了用Filter實現登入許可權驗證的具體程式碼,供大家參考,具體內容如下

使用者在訪問任何介面時,會查詢使用者是否登入過,如果登入過則可以直接訪問,沒有登入的話跳到登入介面

web.xml配置過濾器

<filter>
<filter-name>myFilter</filter-name>
<filter-class>com.zyk.ctrl.MyFilter</filter-class>
 <!-- 配置初始化引數,指明再沒有登入的情況下放行的資源 -->
 <init-param>
 //初始化引數名
  <param-name>letgo</param-name>
  //初始化引數值
  <param-value>/login.jsp;/loginServlet;/css;/images;/js</param-value>
 </init-param>
 </filter>
 <filter-mapping>
 //必須和上面的一樣
 <filter-name>myFilter</filter-name>
 //過濾所有
 <url-pattern>/*</url-pattern>
 
</filter-mapping>

MyFilter.java

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.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

/**
 * Servlet Filter implementation class MyFilter
 */

public class MyFilter implements Filter {
//定義一個存放放行資源路徑的陣列
 private static String[] paths;

 /**
 * Default constructor.
 */
 public MyFilter() {
 // TODO Auto-generated constructor stub
 }

 /**
 * @see Filter#destroy()
 */
 public void destroy() {
 // TODO Auto-generated method stub
 }

 /**
 * @see Filter#doFilter(ServletRequest,ServletResponse,FilterChain)
 */
 public void doFilter(ServletRequest req,ServletResponse res,FilterChain chain)
  throws IOException,ServletException {
 HttpServletRequest request = (HttpServletRequest) req;
 HttpServletResponse response = (HttpServletResponse) res;
  //獲取資源URI路徑
  String path = request.getServletPath();
  
  for (int i = 0; i < paths.length; i++) {
  //如果當前請求的URI路徑是要放行的資源中的一個,放行
  if (path.startsWith(paths[i])) {
   chain.doFilter(request,response);
   return;//放行之後返回,避免程式繼續執行,往下面執行是攔截的程式碼
  }
  
  }
  //判斷使用者是否已經登入,如果登入則放行資源,否則重定向到登入介面
  String name = (String) request.getSession().getAttribute("name");
  //如果name為空,則證明使用者沒有登入過,跳轉到登入介面
  if (name==null) {
  request.getSession().setAttribute("error","尚未登入,請登入");
  response.sendRedirect("/BookManagerSystem/login.jsp");
  return;
  
  }
  //剩下的情況為已登入,放行
  chain.doFilter(request,response); 
 

 }

 /**
 * @see Filter#init(FilterConfig)
 */
 public void init(FilterConfig fConfig) throws ServletException {
 //讀取初始化引數,得到放行的資源
 String initParameter = fConfig.getInitParameter("letgo");
 paths =initParameter.split(";");
 }

}

Servlet.java部分程式碼

if ("login".equals(action)) {
  String name = request.getParameter("name");
  String pwd = request.getParameter("pwd");
  User user = new User(name,pwd);

  if (dao.ValidateLogin(user)) {
  //ValidateLogin為登入驗證方法,如果驗證成功,則設定一個屬性名為“name”值為使用者名稱的session,用於Myfilter驗證是否登入過
  request.getSession().setAttribute("name",name);
  response.sendRedirect("admin/admin.jsp");

  } else {
  request.getSession().setAttribute("error","賬號或者密碼錯誤");
  response.sendRedirect("login.jsp");
  }

 }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。