JAVA - 【Tomcat】Servlet Cookie與Session

目錄

  • Cookie
    • cookie是什麼?
    • javax.servlet.http.Cookie
    • 獲取與添加
    • 示例:上次訪問時間
    • 示例:歷史記錄
  • Session
    • Session原理
    • JSP默認內置session對象
    • 獲得Session
    • API
    • 示例:登錄驗證碼


<一> Cookie

1> cookie是什麼?

客戶端技術,服務器將每個用戶的數據以cookie的形式寫給各自的瀏覽器;

  • 會話級別cookie(MaxAge=-1)
  • 本地cookie(MaxAge>0)
  • 刪除cookie(MaxAge=0)

2> javax.servlet.http.Cookie

名稱必須遵守 RFC 2109。

這意味着它只能包含 ASCII 字母數字字符,不能包含逗號、分號或空格,也不能以 $ 字符開頭;cookie 的名稱在創建之後不得更改。

Cookie:
    javax.servlet.http.Cookie
        cookie值可以唯一標識客戶端
            每個web服務器20個cookie
            總共300個cookie
            每個cookie大小限定4K
        new Cookie(String,String)
                getName()
                getValue(String)
                ck.setPath("/");
                    *注意cookie保存的時間是訪問當前Servlet的時間,與這裏設置的Path無關,這裏的Path只其攜帶作用
                ck.setMaxAge(60*60*24);

3> 獲取與添加

從請求中獲取cookies + 將cookie返回給客戶端

void addCookie(Cookie cookie) 
    HttpServletResponse
        *響應消息頭
            Set-Cookie頭字段

Cookie[] getCookies()
    HttpServletRequest

4> 示例:上次訪問時間

JDK1.8新時間類https://blog.csdn.net/qq_42292831/article/details/105342748

package xyz.kuoa.servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 測試cookie
 * @author X
 *
 */
public class ServletDemo1 extends HttpServlet {

	private static final long serialVersionUID = 1L;

	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		
		response.setContentType("text/html;charset=UTF-8");
		
		//獲取cookie
		Cookie[] cks = request.getCookies();
		String time = "";
		PrintWriter out = response.getWriter();
		for (int i = 0; cks!=null&&i < cks.length; i++) {
			if("lastAccessTime".equals(cks[i].getName())){
				time = cks[i].getValue();
				LocalDateTime tempTime = LocalDateTime.parse(time,DateTimeFormatter.ofPattern("yyyyMMddHHmmss"));
				time = DateTimeFormatter.ofPattern("yyyy年MM月dd日 HH:mm:ss").format(tempTime);
				out.print("你上次訪問的時間爲:"+time);
			}
		}
		
		//寫入cookie
		//cookie參數只能爲ASCII字母數字,不能有其他字符
		String time1 = DateTimeFormatter.ofPattern("yyyyMMddHHmmss").format(LocalDateTime.now());
		Cookie ck = new Cookie("lastAccessTime",time1);
		//訪問哪些路徑時攜帶當前cookie(以該路徑爲前綴)
		//注意cookie保存的時間是訪問當前Servlet的時間,與這裏設置的Path無關,這裏的Path只其攜帶作用
		//ck.setPath("/");
		ck.setMaxAge(60*60*24);
		response.addCookie(ck);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {


	}

}

5> 示例:歷史記錄

  • Book.java
package xyz.kuoa.entity;

public class Book {
	private String id;
	private String name;
	private double price;
	private String author;

	public Book(String id, String name, double price, String author) {
		super();
		this.id = id;
		this.name = name;
		this.price = price;
		this.author = author;
	}

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public double getPrice() {
		return price;
	}

	public void setPrice(double price) {
		this.price = price;
	}

	public String getAuthor() {
		return author;
	}

	public void setAuthor(String author) {
		this.author = author;
	}

	@Override
	public String toString() {
		return "Book [id=" + id + ", name=" + name + ", price=" + price + ", author=" + author + "]";
	}
}
  • DBUtils.java
package xyz.kuoa.util;

import java.util.HashMap;
import java.util.Map;

import xyz.kuoa.entity.Book;

public class DBUtils {
	private static Map<String,Book> books = new HashMap<>();
	
	static{
		books.put("1", new Book("1","《時間簡史》",89.9,"霍金"));
		books.put("2", new Book("2","《C語言入門》",75.9,"小A"));
		books.put("3", new Book("3","《Java入門》",52.9,"小B"));
		books.put("4", new Book("4","《C#入門》",53.9,"小C"));
		books.put("5", new Book("5","《PHP入門》",64.9,"小D"));
	}

	public static Map<String, Book> findAllBooks() {
		return books;
	}
	
	public static Book findBookById(String id){
		return books.get(id);
	}
	
}
  • ServletDemo1.java
package xyz.kuoa.history;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Map;

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 xyz.kuoa.entity.Book;
import xyz.kuoa.util.DBUtils;

public class ServletDemo1 extends HttpServlet {

	private static final long serialVersionUID = 1L;

	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();

		out.print("本網站書籍列表:<br/>");
		Map<String, Book> books = DBUtils.findAllBooks();
		for (Map.Entry<String, Book> b : books.entrySet()) {
			out.print("<a href='" + request.getContextPath() + "/servlet/showBookDetail?id=" + b.getKey()
					+ "' target='_blank'>" + b.getValue().getName() + "<a><br/>");
		}

		out.print("<hr/>您瀏覽過的書籍列表:<br/>");
		Cookie[] cookies = request.getCookies();
		String idString = "";
		for (int i = 0; cookies!=null&&i < cookies.length; i++) {
			if("historyBookId".equals(cookies[i].getName())){
				idString = cookies[i].getValue();
				String[] ids = idString.split("-");
				for (String id : ids) {
					String name = DBUtils.findBookById(id).getName();
					out.print(name+"<br/>");
				}
				break;
			}
		}
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

	}

}
  • ShowBookDetail.java
package xyz.kuoa.history;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;

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 xyz.kuoa.entity.Book;
import xyz.kuoa.util.DBUtils;

public class ShowBookDetail extends HttpServlet {

	private static final long serialVersionUID = 1L;

	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();

		// 顯示圖書的詳細信息
		// 獲得get方式提交的ID
		String id = request.getParameter("id");
		Book book = DBUtils.findBookById(id);
		out.print(book + "<br/>");

		// 把當前瀏覽過得書籍ID寫回到客戶端
		String historyBookId = organizeId(id, request);
		Cookie ck = new Cookie("historyBookId", historyBookId);
		ck.setPath("/");
		//ck.setMaxAge(60 * 60 * 24);
		response.addCookie(ck);
	}

	private String organizeId(String id, HttpServletRequest request) {
		String idString = "";
		Cookie[] cookies = request.getCookies();
		for (int i = 0; cookies != null && i < cookies.length; i++) {
			if ("historyBookId".equals(cookies[i].getName())) {
				idString = cookies[i].getValue();
				break;
			}
		}
		if (idString == "") {
			idString = id;
		} else {
			idString = id+"-"+idString;
			// 去重
			String[] ids = idString.split("-");
			List<String> list = new LinkedList<>();
			Collections.addAll(list, ids);
			for (int i = 0; i < list.size(); i++) {
				for (int j = i + 1; j < list.size(); j++) {
					if (list.get(i).equals(list.get(j))) {
						list.remove(j);
						j--;
					}
				}
			}
			idString = "";
			for (int i = 0; i < list.size(); i++) {
				if(i==0){
					idString = list.get(i);
				}else{
					idString = idString+"-"+list.get(i);
				}
			}
		}
		return idString;
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

	}

}

<二> Session

瀏覽器關閉後一個會話(Session)結束:每個瀏覽器維護一個會話;

爲什麼要使用Session:

  • session是服務端技術,維護自身域對象,同一會話下,一個應用可共享數據;
  • 域對象值可以爲Object,cookie只能爲String(ASCII字母數字字符)

1> Session原理

Session底層依賴cookie

2> JSP默認內置session對象

3> 獲得Session

HttpSession session = request.getSession();
	session.setAttribute("A","AAA");
	String a = (String)session.getAttribute("A");

3> API

  • void setAttribute(String, Object)
  • Object getAttribute(String)
  • void removeAttribute(String)
  • 獲得保存在cookie中的id
    • session.getId();
  • 設置過期時間
    • session.setMaxInactiveInterval(60);
  • 立馬銷燬session
    • session.invalidate();

另一種設置session過期時間的方式(web.xml):

<!-- 單位:分鐘 -->

<session-config>
	<session-timeout>10</session-timeout>
</session-config>

4> 示例:登錄驗證碼

https://kylee.blog.csdn.net/article/details/106403717

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章