欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaWeb 中Cookie實(shí)現(xiàn)記住密碼的功能示例

 更新時(shí)間:2017年06月26日 16:10:23   作者:justdoit_potato  
cookie是一種WEB服務(wù)器通過(guò)瀏覽器在訪問(wèn)者的硬盤(pán)上存儲(chǔ)信息的手段。Cookie的目的就是為用戶帶來(lái)方便,為網(wǎng)站帶來(lái)增值。這篇文章主要介紹了JavaWeb 中Cookie實(shí)現(xiàn)記住密碼的功能示例,需要的朋友可以參考下

本文主要內(nèi)容:

•1、什么是Cookie
•2、Cookie帶來(lái)的好處
•3、Cookie的主要方法 

一、什么是Cookie

cookie是一種WEB服務(wù)器通過(guò)瀏覽器在訪問(wèn)者的硬盤(pán)上存儲(chǔ)信息的手段。Cookie的目的就是為用戶帶來(lái)方便,為網(wǎng)站帶來(lái)增值。雖然有著許多誤傳,事實(shí)上Cookie并不會(huì)造成嚴(yán)重的安全威脅。Cookie永遠(yuǎn)不會(huì)以任何方式執(zhí)行,因此也不會(huì)帶來(lái)病毒或攻擊你的系統(tǒng)。另外,由于瀏覽器一般只允許存放300個(gè)Cookie,每個(gè)站點(diǎn)最多存放20個(gè)Cookie,每個(gè)Cookie的大小限制為4KB,因此Cookie不會(huì)塞滿你的硬盤(pán)。

例如,當(dāng)我們第一次訪問(wèn)網(wǎng)站輸入用戶名密碼時(shí),可以選擇讓系統(tǒng)記住用戶名密碼,下次就不用重新輸入了,這就是典型的Cookie的應(yīng)用。 

二、Cookie帶來(lái)的好處:

cookies給網(wǎng)站和用戶帶來(lái)的好處非常多:

1. Cookie能使站點(diǎn)跟蹤特定訪問(wèn)者的訪問(wèn)次數(shù)、最后訪問(wèn)時(shí)間等

2. Cookie能告訴在線廣告商廣告被點(diǎn)擊的次數(shù),從而可以更精確的投放廣告

3. Cookie有效期限未到時(shí),Cookie能使用戶在不鍵入密碼和用戶名的情況下進(jìn)入曾經(jīng)瀏覽過(guò)的一些站點(diǎn)

4. Cookie能幫助站點(diǎn)統(tǒng)計(jì)用戶個(gè)人資料以實(shí)現(xiàn)各種各樣的個(gè)性化服務(wù)在JSP中,我們也可以使用Cookie,來(lái)編寫(xiě)一些功能強(qiáng)大的應(yīng)用程序。

有些瀏覽器可以禁用Cookie,所以不能使用Cookie來(lái)完成核心的業(yè)務(wù)。 

三、Cookie類的主要方法:

int getMaxAge() 返回Cookie過(guò)期之前的最大時(shí)間,以秒計(jì)算。
int setMaxAge() 設(shè)置Cookie過(guò)期時(shí)間,以秒計(jì)算。
String getName() 返回Cookie的名字
String getValue() 返回Cookie的值。
void setValue(String newValue) cookie創(chuàng)建后設(shè)置一個(gè)新的值。

注:名字和值是我們始終關(guān)心的兩個(gè)部分。稍后會(huì)詳細(xì)介紹getName/setName、getValue/setValue。 

四、代碼舉例:

【實(shí)例】實(shí)現(xiàn)記住密碼、自動(dòng)登錄的功能

新建JavaWeb工程Test06.

login.jsp:

 <%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>Insert title here</title> 
 <%
   String username = "";
  String password = "";
   //獲取當(dāng)前站點(diǎn)的所有Cookie
   Cookie[] cookies = request.getCookies();
  for (int i = 0; i < cookies.length; i++) {//對(duì)cookies中的數(shù)據(jù)進(jìn)行遍歷,找到用戶名、密碼的數(shù)據(jù)
     if ("username".equals(cookies[i].getName())) {
       username = cookies[i].getValue();
    } else if ("password".equals(cookies[i].getName())) {
       password = cookies[i].getValue();
    }
   }
 %> 
 </head>
 <body>
   <form action="login_handler.jsp" method="post">
     username:<input type="text" name="name" value="<%=username%>" /><br/>
    password:<input type="password" name="pwd" value="<%=password%>" /><br/>
    <input type="checkbox" value="y" name="isLogin">自動(dòng)登錄<br/> 
    <input type="submit" value="登錄" />
  </form>
 </body>
 </html>

13行代碼:獲取當(dāng)前站點(diǎn)所有的Cookie。注:這個(gè)Cookie類是在接下來(lái)的login_handler.jsp文件中定義的。

26行的 value="<%=username%>",以及27行的value="<%=password%>",是在16行、18行獲取到的值。

login_handler.jsp:

<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
 <%
   String name = request.getParameter("name");
   String pwd = request.getParameter("pwd");
   String flag = request.getParameter("isLogin"); 
   if (!"admin".equals(name) && !"123".equals(pwd)) {
     response.sendRedirect("error.jsp");
   } else {
     if ("y".equals(flag)) {
      //創(chuàng)建兩個(gè)Cookie對(duì)象
      Cookie nameCookie = new Cookie("username", name);
      //設(shè)置Cookie的有效期為3天
      nameCookie.setMaxAge(60 * 60 * 24 * 3);
      Cookie pwdCookie = new Cookie("password", pwd);
      pwdCookie.setMaxAge(60 * 60 * 24 * 3);
      response.addCookie(nameCookie);
       response.addCookie(pwdCookie);
    }
    response.sendRedirect("success.jsp");
   }
 %>

核心代碼是11行至20行。

11行:如果用戶勾選了“自動(dòng)登錄”,就把用戶名和密碼的信息放到Cookie中。

第15、17行代碼是設(shè)置Cookie的存儲(chǔ)時(shí)間。如果不設(shè)置Cookie的存儲(chǔ)時(shí)間,則默認(rèn)的存儲(chǔ)時(shí)間為0,此時(shí)Cookie保存的數(shù)據(jù)是存放在內(nèi)存中的,當(dāng)瀏覽器關(guān)閉,則Cookie消失失效。

設(shè)置了存儲(chǔ)時(shí)間后,此時(shí)設(shè)置Cookie的數(shù)據(jù)將保存在硬盤(pán)中,不同的瀏覽器存放的具體位置是不一樣的。

谷歌瀏覽器查看cookie的位置:

“菜單-設(shè)置-顯示高級(jí)設(shè)置-內(nèi)容設(shè)置”:

單擊上圖中的“內(nèi)容設(shè)置”,彈出如下界面:

單擊上圖的紅框部分,彈出如下界面:

success.jsp:

<%@ page language="java" contentType="text/html; charset=UTF-8"
   pageEncoding="UTF-8"%>
 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>Insert title here</title>
 </head>
 <body>success.
 </body>
 </html> 

如果登陸成功,就調(diào)到這個(gè)頁(yè)面。

error.jsp:

<%@ page language="java" contentType="text/html; charset=UTF-8"
   pageEncoding="UTF-8"%>
 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>Insert title here</title>
 </head>
 <body>error.
 </body>
 </html>

運(yùn)行程序,當(dāng)輸入正確的用戶名密碼進(jìn)行登錄,并勾選“記住密碼”后,下次再回到登錄界面,就是下面的這個(gè)樣子:

以上所述是小編給大家介紹的JavaWeb 中Cookie實(shí)現(xiàn)記住密碼的功能示例,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 在Java中對(duì)List進(jìn)行分區(qū)的實(shí)現(xiàn)方法

    在Java中對(duì)List進(jìn)行分區(qū)的實(shí)現(xiàn)方法

    在本文中,我們將說(shuō)明如何將一個(gè)列表拆分為多個(gè)給定大小的子列表,也就是說(shuō)在 Java 中如何對(duì)List進(jìn)行分區(qū),文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下
    2024-04-04
  • 關(guān)于JAVA經(jīng)典算法40題(超實(shí)用版)

    關(guān)于JAVA經(jīng)典算法40題(超實(shí)用版)

    本篇文章小編為大家介紹一下,關(guān)于JAVA經(jīng)典算法40題(超實(shí)用版),有需要的朋友可以參考一下
    2013-04-04
  • Spring?Boot簡(jiǎn)單實(shí)現(xiàn)文件上傳功能

    Spring?Boot簡(jiǎn)單實(shí)現(xiàn)文件上傳功能

    這篇文章主要介紹了Spring?Boot簡(jiǎn)單實(shí)現(xiàn)文件上傳功能,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • Java設(shè)計(jì)模式之單例模式簡(jiǎn)析

    Java設(shè)計(jì)模式之單例模式簡(jiǎn)析

    這篇文章主要介紹了Java設(shè)計(jì)模式之單例模式簡(jiǎn)析,單例模式是常用的設(shè)計(jì)模式,在我們的系統(tǒng)乃至在框架中都普遍被用到,單例模式就是使一個(gè)類有且只有一個(gè)實(shí)例用于外部訪問(wèn),這樣大大的節(jié)省了系統(tǒng)的資源,需要的朋友可以參考下
    2023-12-12
  • 一文掌握SpringSecurity?BCrypt密碼加密和解密

    一文掌握SpringSecurity?BCrypt密碼加密和解密

    BCrypt就是一款加密工具,可以比較方便地實(shí)現(xiàn)數(shù)據(jù)的加密工作。也可以簡(jiǎn)單理解為它內(nèi)部自己實(shí)現(xiàn)了隨機(jī)加鹽處理,這篇文章主要介紹了SpringSecurity?BCrypt密碼加密和解密,一文學(xué)會(huì)使用BCryptPasswordEncoder的方法,需要的朋友可以參考下
    2023-04-04
  • debug模式遲遲不能啟動(dòng)問(wèn)題及解決

    debug模式遲遲不能啟動(dòng)問(wèn)題及解決

    在使用Debug模式進(jìn)行代碼測(cè)試時(shí),由于設(shè)置了過(guò)多的斷點(diǎn),導(dǎo)致程序加載緩慢甚至無(wú)法啟動(dòng),解決此問(wèn)題的方法是取消不必要的斷點(diǎn),通過(guò)IDE的斷點(diǎn)管理功能,檢查并移除問(wèn)題斷點(diǎn),從而優(yōu)化調(diào)試效率,分享此經(jīng)驗(yàn)希望能幫助遇到相同問(wèn)題的開(kāi)發(fā)者
    2022-11-11
  • 解決SpringMVC接收不到ajaxPOST參數(shù)的問(wèn)題

    解決SpringMVC接收不到ajaxPOST參數(shù)的問(wèn)題

    今天小編就為大家分享一篇解決SpringMVC接收不到ajaxPOST參數(shù)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • java使用Socket實(shí)現(xiàn)SMTP協(xié)議發(fā)送郵件

    java使用Socket實(shí)現(xiàn)SMTP協(xié)議發(fā)送郵件

    這篇文章主要為大家詳細(xì)介紹了java使用Socket實(shí)現(xiàn)SMTP協(xié)議發(fā)送郵件的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Spring事務(wù)annotation原理詳解

    Spring事務(wù)annotation原理詳解

    這篇文章主要介紹了Spring事務(wù)annotation原理詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • 面試突擊之跨域問(wèn)題的解決方案詳解

    面試突擊之跨域問(wèn)題的解決方案詳解

    跨域問(wèn)題本質(zhì)是瀏覽器的一種保護(hù)機(jī)制,它的初衷是為了保證用戶的安全,防止惡意網(wǎng)站竊取數(shù)據(jù)。那怎么解決這個(gè)問(wèn)題呢?接下來(lái)我們一起來(lái)看
    2022-09-09

最新評(píng)論