一、會話的概念
會話可簡單理解爲:用戶開一個瀏覽器,點擊多個超鏈接,訪問服務器多個web資源,然後關閉瀏覽器,整個過程稱之爲一個會話。
有狀態會話:一個同學來過教室,下次再來教室,我們會知道這個同學曾經來過,這稱之爲有狀態會話。
二、會話過程中要解決的一些問題?
每個用戶在使用瀏覽器與服務器進行會話的過程中,不可避免各自會產生一些數據,程序要想辦法爲每個用戶保存這些數據。
三、保存會話數據的兩種技術
3.1、Cookie
Cookie是客戶端技術,程序把每個用戶的數據以cookie的形式寫給用戶各自的瀏覽器。當用戶使用瀏覽器再去訪問服務器中的web資源時,就會帶着各自的數據去。這樣,web資源處理的就是用戶各自的數據了。
3.2、Session
Session是服務器端技術,利用這個技術,服務器在運行時可以爲每一個用戶的瀏覽器創建一個其獨享的session對象,由於session爲用戶瀏覽器獨享,所以用戶在訪問服務器的web資源時,可以把各自的數據放在各自的session中,當用戶再去訪問服務器中的其它web資源時,其它web資源再從用戶各自的session中取出數據爲用戶服務。
### Cookie
構造器 :
Cookie cookie = new Cookie(String name,String value);
Cookie cookie = new Cookie(String name,String value);
Cookie cookie = new Cookie(String name,String value);
服務器響應cookie給客戶端
Response.addCookie(Cookie);
Response.addCookie(Cookie);
Response.addCookie(Cookie);
服務查看用戶帶來的請求是否有cookie
Cookie[] cookies = Request.getCookie();
//可以使用cookie來驗證用戶是否來過
//判斷cookies是否爲空,然後遍歷即可
Cookie.getName();
Cookie.getValue();
cookie測試用戶是否來過
package com.westos.serlvet;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public class CookieTest extends HttpServlet {
boolean flag = false;
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//解決亂碼問題:
request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("UTF-8");
//檢查請求的人是否帶了Cookie
//通過用戶的請求,檢查它是否有cookie
Cookie[] cookies = request.getCookies();
System.out.println("cookie:"+cookies);
if (flag){//如果flag是真,來過
if (cookies!=null){//你有cookie
for (int i = 0; i < cookies.length ; i++) {
Cookie cookie = cookies[i];
if (cookie.getName().equals("lastLoginTime")){
response.getWriter().println("你上一次來的時間爲:"+cookie.getValue());
System.out.println("刷新了cookie");
}
}
}
}else { //如果flag是真,沒來過
response.getWriter().println("你是第一次來,還想要會員套餐");
System.out.println("給該用戶一個cookie");
}
//建立一個cookie
Cookie cookie = new Cookie("lastLoginTime",System.currentTimeMillis()+"");
//設置cookie保存的時間 //cookie.setMaxAge();
//把這個cookie發給客戶端
response.addCookie(cookie);
//response.addCookie(new Cookie("lastLoginTime",System.currentTimeMillis()+""));
flag = true;
}
}
Session
只要客戶端一旦連接上服務器,服務器就會自動產生Session;
一個連接對應一個session,session可以在一個會話中傳遞信息;
通過setAttribute設置值。
通過getAttribute獲得值。
由服務器端控制,服務器如果重啓了,信息就會丟失!
package com.westos.serlvet;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
public class SessionTest extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req,resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//解決亂碼問題:
req.setCharacterEncoding("UTF-8");
resp.setCharacterEncoding("UTF-8");
//Session由服務器自動創建,如何獲得session
//HttpSession 得到的sessioin對象
HttpSession session = req.getSession();
//得到sessionID,一次會話,一個seesionID;
String id = session.getId();
resp.getWriter().println("獲得的sessionId:\n"+id);
String name = "qinjiang";
//向session中存入一個值;
session.setAttribute("name",name);
resp.getWriter().println("存入信息成功:"+name);
}
}
會話註銷方法一:
session.invalidate();//通過代碼註銷會話
會話註銷方法二:
<!--session-config可以設置會話自動過期,時間分鐘爲單位-->
<session-config>
<session-timeout>1</session-timeout>
</session-config>