Asp.Net MVC記住使用者登入資訊下次直接登入功能

發表於2019-11-02

有的時候做網站,就需要記住使用者登入資訊,下次再登入網站時,不用重複輸入使用者名稱和密碼,原理是瀏覽器的cookie把狀態給記住了!這篇文章主要介紹了Asp.Net MVC記住使用者登入資訊下次直接登入功能,需要的朋友可以參考下

那麼具體是怎麼實現的呢?下面博主將一部分程式碼貼出來,想要完整版的Demo可以到百度雲和碼雲下載,

百度雲下載連結:https://pan.baidu.com/s/19pL-koHI9UnVd4bK3Fpuyg 密碼: nud3

馬雲下載連結:https://gitee.com/WuFengZui/RememberLoginDemo      【沒有下載連結的都是耍流氓  哈哈!!】

 我們們先來看看效果圖:

下面是新增Cookie的程式碼,不過這個方法是我封裝過的,方法中的具體操作可以檢視第二段程式碼

//建立Cookie【防止登入資訊洩露,這裡使用Encode()將資訊進行了加密】
    SqlHelper.SetCookie("NameCookie", SqlHelper.Encode(UserName), DateTime.Now.AddDays(7));
    SqlHelper.SetCookie("PwdCookie", SqlHelper.Encode(Pwd), DateTime.Now.AddDays(7));
  //獲取Cookie
    string name = SqlHelper.GetCookieValue("NameCookie");
    string pwd = SqlHelper.GetCookieValue("PwdCookie");
  //刪除Cookie
  SqlHelper.RemoveCookie("NameCookie");
  SqlHelper.RemoveCookie("PwdCookie");

封裝新增Cookie方法

/// <summary>
    /// 設定Cookie值和過期時間
    /// </summary>
    /// <param name="cookieName">Cookie名稱</param>
    /// <param name="value">值</param>
    /// <param name="expires">過期時間</param>
    public static void SetCookie(string cookieName, string value, DateTime expires)
    {
      HttpCookie cookie = HttpContext.Current.Request.Cookies[cookieName];
      if (cookie != null)
      {
        cookie.Value = value;
        cookie.Expires = expires;
        HttpContext.Current.Response.Cookies.Add(cookie);
      }
      else
      {
        cookie = new HttpCookie(cookieName);
        cookie.Value = value;
        cookie.Expires = expires;
        HttpContext.Current.Response.Cookies.Add(cookie);
      }
    }

封裝獲取Cookie方法   

/// <summary>
   /// 獲得Cookie的值
   /// </summary>
   /// <param name="cookieName">Cookie名稱</param>
   /// <returns></returns>
   public static string GetCookieValue(string cookieName)
   {
     HttpCookie cookie = HttpContext.Current.Request.Cookies[cookieName];
     if (cookie == null)
       return "";
     else
       return cookie.Value;
   }

封裝刪除Cookie方法  

/// <summary>
 /// 刪除Cookie的值
 /// </summary>
 /// <param name="cookieName">Cookie名稱</param>
 /// <returns></returns>
 public static void RemoveCookie(string cookieName)
 {
   SetCookie(cookieName, "", DateTime.Now.AddDays(1));
 }

總結

以上所述是小編給大家介紹的Asp.Net MVC記住使用者登入資訊下次直接登入功能,希望對大家有所幫助

相關文章