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

利用JSP session對象保持住登錄狀態(tài)

 更新時間:2017年05月20日 16:44:50   作者:sunny1996  
這篇文章主要為大家詳細介紹了如何利用JSP session對象保持住登錄狀態(tài),具有一定的參考價值,感興趣的小伙伴們可以參考一下

http協(xié)議本身是一種無狀態(tài)的協(xié)議,也就是客戶端連續(xù)發(fā)送的多個請求之間沒有聯(lián)系,下一次請求不關心上一次請求的狀態(tài)。

而實際運用中卻希望服務器能記住客戶端請求的狀態(tài),比如在網(wǎng)上購物系統(tǒng)中,服務器端應該能夠識別并跟蹤每個登錄到系統(tǒng)中的用戶挑選并購買商品的整個流程 。為此,web服務器必須采用一種機制來唯一地標識一個用戶,同時記錄該用戶的狀態(tài),這就要用到會話跟蹤技術。

Java Web使用Session來跟蹤會話和管理會話內(nèi)的狀態(tài)。

Session對象是一個jsp內(nèi)置對象,它在第一個jsp頁面被裝載時自動創(chuàng)建,完成會話期管理。

從一個客戶打開瀏覽器并連接到服務器開始,到客戶關閉瀏覽器離開這個服務器結束,被稱為一個會話。當一個客戶訪問一個服務器時,可能會在這個服務器的幾個頁面之間反復連接,反復刷新一個頁面,服務器應當通過某種辦法知道這是同一個客戶,這就需要session對象。

當發(fā)生以下四種情形其中之一時,session對象中的數(shù)據(jù)便會清空 :
用戶關閉目前正在使用的瀏覽器程序。
關閉網(wǎng)頁服務器。
用戶未向服務器提出請求超過預設的時間,Tomcat服務器預設為30分鐘。
運行程序結束session。

1.建立session變量

在JSP中不需要特別設置程序代碼來建立用戶session,當程序使用了session對象時,便會自動建立session,而下面這行語句便是在session中新增變量數(shù)據(jù)的方式:
session.setAttribute(“變量名稱”,變量內(nèi)容)
變量內(nèi)容可為字符串或者其他對象類型,接著讓我們來看看如何使用這個方法在session中設置變量數(shù)據(jù):

<% 
session.setAttribute(“id”,”編號”); //設置字符串 
session.setAttribute(“expire”,new Date(86400*10)); //設置日期 
session.setAttribute(“l(fā)evel”,new Integer(3)); //設置整數(shù) 
%> 

2.返回session中的變量

在session中設置了變量數(shù)據(jù)后,在其他的各個網(wǎng)頁中便可使用getAttribute讀取其中的內(nèi)容,此方法所返回的數(shù)據(jù)類型為對象(Object)類型,語法如下:
session.getAttribute(“變量名稱”)

3.返回所有session中的變量名稱

getAttributeNames()方法可以取出session中所有變量的名稱,其結果為一個枚舉類的實例。語法為:
session.getAttributeNames()

4.清除session中的變量
removeAttribute()方法可以清除session中的變量數(shù)據(jù),使用語法如下:
session.removeAttribute(“變量名稱”)

5.結束session

對于已經(jīng)建立的session,可使用invalidate()方法將其結束,使用語法為:
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是否為空來判斷是否登錄過了,并且傳遞相關的參數(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>

可以看到,登錄以后,不管跳轉到哪個頁面,用戶的登錄狀態(tài)都沒有丟失

一旦logout登出以后,session.invalidate()方法被調(diào)用,session被銷毀,就跟蹤不到用戶的登錄信息了

同時,如果我采用另一個瀏覽器訪問同樣的頁面,以“2號用戶”為username登錄,也會一直記錄到這個用戶的登錄信息(不過如果是同一種瀏覽器的話就不行了)

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

相關文章

最新評論