亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java實現(xiàn)用戶自動登錄

 更新時間:2021年08月15日 10:38:31   作者:鄭宏鑫erke  
這篇文章主要為大家詳細介紹了java用戶自動登錄的實現(xiàn)方法,分為六個步驟實現(xiàn)用戶自動登錄,并驗證用戶是否已經(jīng)登錄,感興趣的小伙伴們可以參考一下

自動登錄,是為了幫助用戶多次使用這個網(wǎng)頁時,不用再次輸入用戶名和密碼就可以登錄。

自動登錄是指用戶將用戶的登錄信息,人,保存到本地的文件中Cookie中。

Name,value -聲明時 new Cookie(key,value); 

Path-默認值,即為當前保存cookie的這個serlvet所在的路徑。

如果Cookie在這樣的路徑:http://loclhost:8080/project/abc/AServlet

則Cookie的路徑為: http://loclhost/project/abc

則說明:

所在在http://loclhost/project/abc目錄下的servlet才可以讀取這個cookie的值。 

如果:

保存Cookie類:http://loclhost:8080/project/a/b/AServlet

則Cookie的默認path為http://loclhost/project/a/b

第一步:開發(fā)一個登錄頁面

<c:choose>

  <c:when test="${empty sessionScope.name}">
    <form name="x" method="post" action="<c:url value='/LoginServlet'/>">
      Name:<input type="text" name="name"/><br/>
      auto:
      <input type="radio" name="auto" value="-1">不自動登錄
      <br/>
      <input type="radio" name="auto" value="1">1天<br/>
      <input type="radio" name="auto" value="7">1周<br/>
      <input type="submit"/>
    </form>
  </c:when>
  <c:otherwise>

    你已經(jīng)登錄了:${name}<br/>
    <a href="<c:url value='/LoginServlet'/>">退出</a>
  </c:otherwise>

</c:choose>

第二步:成功保存cookie

public void doPost(HttpServletRequest request, HttpServletResponse response)

      throws ServletException, IOException {
    //接收用戶姓名
    String name = request.getParameter("name");
    String auto = request.getParameter("auto");
    //將用戶信息放到session
    request.getSession().setAttribute("name",name);
    //判斷auto是否是-1
    if(!auto.equals("-1")){
      int day = Integer.parseInt(auto);//1|7
      int seconds = 60*60*24*day;
      //聲明cookie
      Cookie c = new Cookie("autoLogin",name);
      c.setMaxAge(seconds);
      c.setPath(request.getContextPath());
      //保存cookie
      response.addCookie(c);
     

    }

  }

第三步:要求訪問本網(wǎng)點中任何一個頁面都應該實現(xiàn)自動登錄

寫一個過慮器,對所有url=/*進行過慮。在doFilter中讀取所有cookie。是否存在名稱為autoLogin的名稱cookie。

永遠都放行。

public void doFilter(ServletRequest request, ServletResponse response,

    FilterChain chain) throws IOException, ServletException {
    //在這兒讀取cookie
    HttpServletRequest req = (HttpServletRequest) request;
    //獲取所的有cookie
    Cookie[] cs = req.getCookies();
    if(cs!=null){
      for(Cookie c:cs){
       if(c.getName().equals("autoLogin")){//如果存在自動登錄的cookie
         String value = c.getValue();//用戶名稱

         //登錄成功是指
         req.getSession().setAttribute("name", value);
         break;

       }

      }

    }

    //不管是否自動登錄成

    chain.doFilter(request, response);

  }

第四涉:配置到web.xml中對所有url=/*

<filter>

  <filter-name>auto</filter-name>
  <filter-class>cn.itcast.filter.AutoFilter</filter-class>
  </filter>
  <filter-mapping>
  <filter-name>auto</filter-name>
  <url-pattern>/*</url-pattern>
 </filter-mapping>

第五步:開發(fā)退出

System.err.println("用戶退出");

    //刪除整個session
    request.getSession().invalidate();
    Cookie c = new Cookie("autoLogin", "ddd");
    c.setMaxAge(0);
    c.setPath(request.getContextPath());
    response.addCookie(c);
//  request.getSession().removeAttribute("name");
    response.sendRedirect(request.getContextPath()+"/index.jsp");

第六步:優(yōu)化代碼

由于用戶在做手工登錄時,也會進入AutoFiilter的doFilter方法,且讀取所有Cookie遍歷一次。而這次遍歷對用戶來說是多余。

所以應該將LoginServet這個url在doFiler中不過過慮。

且對退出也不能自動登錄。

補充知識點:

驗證用戶是否已經(jīng)登錄

package cn.hongxin.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{

  public void init(FilterConfig filterConfig) throws ServletException {

  }
  public void doFilter(ServletRequest request, ServletResponse response,
      FilterChain chain) throws IOException, ServletException {
    //將request強轉(zhuǎn)成htt...
    HttpServletRequest req = (HttpServletRequest) request;
    //獲取session
    HttpSession ss = req.getSession();
    //從session中獲取user
    if(ss.getAttribute("user")==null){
      System.err.println("你還沒有登錄");
      req.getSession().setAttribute("msg", "請你先登錄");

      //重定向到登錄
      HttpServletResponse resp = (HttpServletResponse) response;
      resp.sendRedirect(req.getContextPath()+"/index.jsp");[W2] 
    }else{

      //放行
      chain.doFilter(request, response);

    }

  }

  public void destroy() {

  }

}

配置到web.xml中且對jsps/*進行過慮:

<filter>

  <filter-name>login</filter-name>
  <filter-class>cn.itcast.filter.LoginFilter</filter-class>
 </filter>
 <filter-mapping>
  <filter-name>login</filter-name>
  <url-pattern>/jsps/*</url-pattern>
  <url-pattern>/views/*</url-pattern>
 </filter-mapping>

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。

相關(guān)文章

  • 超細講解Java調(diào)用python文件的幾種方式

    超細講解Java調(diào)用python文件的幾種方式

    有時候我們在寫java的時候需要調(diào)用python文件,下面這篇文章主要給大家介紹了關(guān)于Java調(diào)用python文件的幾種方式,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • Java?NIO與IO的區(qū)別以及比較

    Java?NIO與IO的區(qū)別以及比較

    這篇文章主要介紹了Java?NIO與IO的區(qū)別以及比較,文章通過圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • 關(guān)于Java中靜態(tài)代碼塊的執(zhí)行淺析

    關(guān)于Java中靜態(tài)代碼塊的執(zhí)行淺析

    這篇文章主要給大家介紹了關(guān)于Java中靜態(tài)代碼塊執(zhí)行的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-09-09
  • java開發(fā)時各類工具的使用規(guī)范

    java開發(fā)時各類工具的使用規(guī)范

    這篇文章主要介紹了java編碼時各類工具的使用規(guī)范,多人協(xié)作、共同開發(fā)一個項目,如果沒有統(tǒng)一的代碼規(guī)范的話,項目中的每個人都按照自己的習慣率性而為,就會導致整個項目的代碼看上去雜亂無章,可讀性非常差,并且持續(xù)增加后續(xù)的維護成本。對此感興趣可以來了解一下
    2020-07-07
  • 簡單理解遵循接口隔離原則的Java設(shè)計模式編程

    簡單理解遵循接口隔離原則的Java設(shè)計模式編程

    這篇文章主要介紹了遵循接口隔離原則的Java設(shè)計模式編程,針對Java編程中interface接口方面的編寫進行約束,需要的朋友可以參考下
    2016-02-02
  • 淺談MyBatis通用Mapper實現(xiàn)原理

    淺談MyBatis通用Mapper實現(xiàn)原理

    這篇文章主要介紹了淺談MyBatis通用Mapper實現(xiàn)原理,本文會先介紹通用 Mapper 的簡單原理,然后使用最簡單的代碼來實現(xiàn)這個過程。感興趣的小伙伴們可以參考一下
    2018-10-10
  • Java正則表達式驗證固定電話號碼符合性

    Java正則表達式驗證固定電話號碼符合性

    這篇文章主要介紹了Java正則表達式驗證固定電話號碼符合性的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • 去掉 IDEA 中 mybatis配置文件的局部背景顏色(圖解)

    去掉 IDEA 中 mybatis配置文件的局部背景顏色(圖解)

    這篇文章通過圖文并茂的形式給大家介紹了去掉IntelliJ IDEA 中 mybatis配置文件的局部背景顏色及mybatis 對應的 xml 文件警告的方法圖解,需要的朋友可以參考下
    2018-09-09
  • redis與ssm整合方法(mybatis二級緩存)

    redis與ssm整合方法(mybatis二級緩存)

    本文給大家介紹redis與ssm整合方法(mybatis二級緩存)。主要是利用redis去做mybatis的二級緩存,mybaits映射文件中所有的select都會刷新已有緩存,如果不存在就會新建緩存,所有的insert,update操作都會更新緩存
    2017-12-12
  • 詳解Java排序算法中的冒泡和選擇排序

    詳解Java排序算法中的冒泡和選擇排序

    這篇文章主要給大家介紹了Java排序算法中的冒泡排序和選擇排序,文中有詳細的圖文解釋和代碼示例,對我們學習Java算法有一定的幫助,感興趣的同學可以參考閱讀下
    2023-06-06

最新評論