JSP——Cookie物件簡介
阿新 • • 發佈:2018-12-21
1.概述
Cookie(客戶端,不是內建物件):Cookie是由伺服器生成的,在傳送給客戶端儲存。 相當於本地快取的作用:客戶端——>服務端 比如你線上看視訊,你看視訊是從服務端讀取的,看完視訊,下一次看就不用在快取了。 作用: 提高訪問服務端的效率,但是安全性較差。
2.方法屬性
Cookie:name=value 繼承於java.servlet.http.Cookie public Cookie(String name,value) String getName()獲取name String getValue()獲取value void setMaxAge(int expiry):最大有效期(即快取的儲存時間)以秒為單位
伺服器傳送Cookie到客戶端 response.addCookie(Cookie cookie) 頁面跳轉(轉發,重定向) 客戶端獲取Cookie request.getCookie();
a.服務端增加cookie:response物件 客戶端獲取cookie:request物件。 b.不能直接獲取某一個單獨物件,只能一次性將全部的cookie拿到,不能說一個一個拿。(就是指快取了a視訊和b視訊,不能選擇性的拿某一個而是兩個都得拿到客戶端)
3.例項解析
使用一個頁面設定cookie的name和value,頁面為addCookie.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> <% Cookie cookie1 = new Cookie("name","zs"); Cookie cookie2 = new Cookie("pwd","123"); response.addCookie(cookie1); response.addCookie(cookie2); //將Cookie資訊傳送到客戶端request.jsp 頁面獲取 response.sendRedirect("request.jsp"); %> </body> </html>
用來接收Cookie資訊的頁面request.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> <% //因為那邊的Cookie是多個所以定義陣列儲存接收 Cookie cookies[] = request.getCookies(); for(Cookie cookie:cookies){ out.print(cookie.getName()+"---"+cookie.getValue()+"<br/>"); } %> </body> </html>
結果: 可以看到已經得到了我們需要的cookie了,劃紅線的其實是預設的cookie物件,可以按f12進入開發者模式在進入網路 如下: 其實是預設的。