利用JSP session對象保持住登錄狀態(tài)
http協(xié)議本身是一種無狀態(tài)的協(xié)議,也就是客戶端連續(xù)發(fā)送的多個請求之間沒有聯(lián)系,下一次請求不關(guān)心上一次請求的狀態(tài)。
而實際運(yùn)用中卻希望服務(wù)器能記住客戶端請求的狀態(tài),比如在網(wǎng)上購物系統(tǒng)中,服務(wù)器端應(yīng)該能夠識別并跟蹤每個登錄到系統(tǒng)中的用戶挑選并購買商品的整個流程 。為此,web服務(wù)器必須采用一種機(jī)制來唯一地標(biāo)識一個用戶,同時記錄該用戶的狀態(tài),這就要用到會話跟蹤技術(shù)。
Java Web使用Session來跟蹤會話和管理會話內(nèi)的狀態(tài)。
Session對象是一個jsp內(nèi)置對象,它在第一個jsp頁面被裝載時自動創(chuàng)建,完成會話期管理。
從一個客戶打開瀏覽器并連接到服務(wù)器開始,到客戶關(guān)閉瀏覽器離開這個服務(wù)器結(jié)束,被稱為一個會話。當(dāng)一個客戶訪問一個服務(wù)器時,可能會在這個服務(wù)器的幾個頁面之間反復(fù)連接,反復(fù)刷新一個頁面,服務(wù)器應(yīng)當(dāng)通過某種辦法知道這是同一個客戶,這就需要session對象。
當(dāng)發(fā)生以下四種情形其中之一時,session對象中的數(shù)據(jù)便會清空 :
用戶關(guān)閉目前正在使用的瀏覽器程序。
關(guān)閉網(wǎng)頁服務(wù)器。
用戶未向服務(wù)器提出請求超過預(yù)設(shè)的時間,Tomcat服務(wù)器預(yù)設(shè)為30分鐘。
運(yùn)行程序結(jié)束session。
1.建立session變量
在JSP中不需要特別設(shè)置程序代碼來建立用戶session,當(dāng)程序使用了session對象時,便會自動建立session,而下面這行語句便是在session中新增變量數(shù)據(jù)的方式:
session.setAttribute(“變量名稱”,變量內(nèi)容)
變量內(nèi)容可為字符串或者其他對象類型,接著讓我們來看看如何使用這個方法在session中設(shè)置變量數(shù)據(jù):
<% session.setAttribute(“id”,”編號”); //設(shè)置字符串 session.setAttribute(“expire”,new Date(86400*10)); //設(shè)置日期 session.setAttribute(“l(fā)evel”,new Integer(3)); //設(shè)置整數(shù) %>
2.返回session中的變量
在session中設(shè)置了變量數(shù)據(jù)后,在其他的各個網(wǎng)頁中便可使用getAttribute讀取其中的內(nèi)容,此方法所返回的數(shù)據(jù)類型為對象(Object)類型,語法如下:
session.getAttribute(“變量名稱”)
3.返回所有session中的變量名稱
getAttributeNames()方法可以取出session中所有變量的名稱,其結(jié)果為一個枚舉類的實例。語法為:
session.getAttributeNames()
4.清除session中的變量
removeAttribute()方法可以清除session中的變量數(shù)據(jù),使用語法如下:
session.removeAttribute(“變量名稱”)
5.結(jié)束session
對于已經(jīng)建立的session,可使用invalidate()方法將其結(jié)束,使用語法為:
session.invalidate()
其他的一些可能會用到的方法:
現(xiàn)在寫一個實例:通過session來記錄客戶的登錄狀態(tài):
index.jsp登錄界面:
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>$Title$</title> </head> <body> <form action="process_login.jsp" method="post"> 用戶名:<input type="text" name="username"> 密碼:<input type="text" name="password"> <input type="submit" value="submit"> <input type="reset" value="reset"> </form> <a href="page1.jsp" rel="external nofollow" rel="external nofollow" >1</a> <a href="page2.jsp" rel="external nofollow" rel="external nofollow" >2</a> <a href="page3.jsp" rel="external nofollow" rel="external nofollow" >3</a> </body> </html>
process_login.jsp處理登錄數(shù)據(jù),這里知道輸入密碼是123都可以登錄成功:
session.getAttribute()將會告訴page1.jsp文件這個用戶是否登錄成功了
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <% String username=request.getParameter("username"); String password=request.getParameter("password"); if (password.equals("123")){ session.setAttribute("username",username); } response.sendRedirect("page1.jsp"); %>
logout.jsp登出
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <% session.invalidate(); response.sendRedirect("index.jsp"); %>
page1.jsp, page2.jsp, page3.jsp大同小異顯示不同的頁面,用于驗證登錄狀態(tài)的記錄(這里僅以page1.jsp為例):
注意這里的判斷邏輯是一種很有趣的寫法,把jsp代碼和html代碼完全融合起來了,不過我覺得這樣寫還是比較亂,寧愿只用一個jsp代碼段,里面用out.println()在html中來實現(xiàn)顯示不同的內(nèi)容
這里主要是靠判斷session.username是否為空來判斷是否登錄過了,并且傳遞相關(guān)的參數(shù)信息
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Title</title> </head> <body> 這里是Page1<br> <%if (session.getAttribute("username")==null){%> 用戶還沒有登錄 <%}else {%> 已登錄,用戶名:<%= session.getAttribute("username")%> <%}%> <br> <a href="page1.jsp" rel="external nofollow" rel="external nofollow" >page1</a> <a href="page2.jsp" rel="external nofollow" rel="external nofollow" >page2</a> <a href="page3.jsp" rel="external nofollow" rel="external nofollow" >page3</a> <a href="index.jsp" rel="external nofollow" >login</a> <a href="logout.jsp" rel="external nofollow" >logout </a> </body> </html>
可以看到,登錄以后,不管跳轉(zhuǎn)到哪個頁面,用戶的登錄狀態(tài)都沒有丟失
一旦logout登出以后,session.invalidate()方法被調(diào)用,session被銷毀,就跟蹤不到用戶的登錄信息了
同時,如果我采用另一個瀏覽器訪問同樣的頁面,以“2號用戶”為username登錄,也會一直記錄到這個用戶的登錄信息(不過如果是同一種瀏覽器的話就不行了)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于IIS連接數(shù)和在線人數(shù)的詳細(xì)說明
這篇文章主要為大家介紹下IIS連接數(shù)和在線人數(shù)的詳細(xì)說明需要的朋友可以參考下2006-10-10JSP連接MySql/MS SQL Server/Oracle數(shù)據(jù)庫連接方法[整理]
這個經(jīng)常整理更新2008-10-10jsp+ajax實現(xiàn)的局部刷新較驗驗證碼(onblur事件觸發(fā)較驗)
這篇文章主要介紹了jsp+ajax實現(xiàn)的局部刷新較驗驗證碼,基于onblur事件觸發(fā)較驗功能,以實例形式詳細(xì)的分析了前臺顯示、圖片生成及Ajax動態(tài)驗證等詳細(xì)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10Hibernate識別數(shù)據(jù)庫特有字段實例詳解
這篇文章主要介紹了Hibernate識別數(shù)據(jù)庫特有字段實例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06JSP隱含對象response實現(xiàn)文件下載的兩種方法
JSP隱含對象response實現(xiàn)文件下載的兩種方式,二進(jìn)制文件的下載與文本文件下載2014-09-09