1. 程式人生 > >JSP——Cookie物件簡介

JSP——Cookie物件簡介

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進入開發者模式在進入網路 如下: 其實是預設的。