Cookie读写操作

Cookie

浏览器与WEB服务器之间是使用HTTP协议进行通信的,当某个用户发出页面请求时,WEB服务器只是简单的进行响应,然后就关闭与该用户的连接。因此当一个请求发送到WEB服务器时,无论其是否是第一次来访,服务器都会把它当作第一次来对待,这样的不好之处可想而知。为了弥补这个缺陷,Netscape开发出了cookie这个有效的工具来保存某个用户的识别信息。cookies是一种WEB服务器通过浏览器在访问者的硬盘上存储信息的手段:Netscape Navigator使用一个名为cookies.txt本地文件保存从所有站点接收的Cookie信息;而IE浏览器把Cookie信息保存在类似于 C://windows//cookies的目录下。当用户再次访问某个站点时,服务端将要求浏览器查找并返回先前发送的Cookie信息,来识别这个用户。

jsp是通过以下语法格式来创建Cookie的

Cookie cookie_name =new Cookie("Parameter","Value");
//例如
Cookie username_Cookie = new Cookie("username","zhangsan"); 
response.addCookie(username_Cookie);

JSP是调用Cookie对象相应的构造函数Cookie(name,value)用合适的名字和值来创建Cookie,然后Cookie可以通过response的addCookie方法加入到Set-Cookie应答头

Cookie的各种方法
  • String getComment():返回cookie中注释,如果没有注释的话将返回空值
  • String getDomain():返回cookie中Cookie适用的域名 使用getDomain() 方法可以指示浏览器把Cookie返回给同 一域内的其他服务器,而通常Cookie只返回给与发送它的服务器名字完全相同的服务器。注意域名必须以点开始(例如.wmathor.com
  • int getMaxAge():返回Cookie过期之前的最大时间,以秒计算
  • String getName():返回Cookie的名字
  • String getPath():返回Cookie适用的路径。如果不指定路径,Cookie将返回给当前页面所在目录及其子目录下的所有页面
  • boolean getSecure():如果浏览器通过安全协议发送cookies将返回true值,如果浏览器使用标准协议则返回false值
  • String getValue():返回Cookie的值
  • int getVersion():返回Cookie所遵从的协议版本
  • void setComment(String purpose):设置cookie注释
  • void setDomain(String pattern):设置cookie中Cookie适用的域名
  • void setMaxAge(int expiry):以秒计算,设置Cookie过期时间
  • void setValue(String newValue):Cookie创建后设置一个新的值
  • void setVersion(int v):设置Cookie遵从的协议版本
  • void setSecure(boolean flag):指出浏览器使用的安全协议,例如HTTPS或SSL
写入Cookie
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>Cookie Write page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
</head>
<body>
	<% 
		Cookie cookie_a = new Cookie("a_name","a_value");//name,value
		response.addCookie(cookie_a);
		
		Cookie cookie_b = new Cookie("b_name","b_value");
		cookie_b.setMaxAge(30 * 24 * 60 * 60);//单位是秒
		response.addCookie(cookie_b);
		
		Cookie cookie_c = new Cookie("c_name","c_value");
		cookie_c.setMaxAge(-1);
		//-1是一个session Cookie,浏览器打开有用,关闭时删除
		//cookie_c.setPath(当前路径);默认有一个调用
		response.addCookie(cookie_c);
		
		Cookie cookie_d = new Cookie("d_name","d_value");
		cookie_d.setMaxAge(30 * 24 * 60 * 60);//单位是秒
		cookie_d.setPath("/jsp");
		response.addCookie(cookie_d);
		
		Cookie cookie_e = new Cookie("e_name","e_value");
		cookie_e.setMaxAge(30 * 24 * 60 * 60);//单位是秒
		cookie_e.setPath("/");//服务器的根目录
		response.addCookie(cookie_e);
	%>
	<!--HttpSession 
			设置Session的最大呆滞时间
			销毁Session invalidate
			获取SessionID SessionId
			Object getAttribute(String name)
			void setAttribute(String name,Object value);
			
		application
			ServerletContext
			Object getAttribute(String name)
			void setAttribute(String name,Object value);
	-->	
	<a href = "/jsp/c03/cookie.jsp">返回</a>
</body>
</html>
读Cookie
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>Cookie Read page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<jsp:include page = "../res.jsp"></jsp:include>
</head>
<body class = "container">
	<%
		Cookie[] cookies = request.getCookies();
		if(cookies == null || cookies.length == 0) {
			out.print("没有Cookie");
			return;
		}
	%>
	<table class = "table table-bordered">
	<% 
		for(Cookie cookie : cookies) {
	%>
			<tr>
				<td><%= cookie.getName() %></td>
				<td><%= cookie.getValue() %></td>
				<td><%= cookie.getMaxAge() %></td>
				<td><%= cookie.getDomain() %></td>
				<td><%= cookie.getPath() %></td>
			</tr>
	<%
		}
	%>
	</table>
	<% 
				
	%>
	<a href = "/jsp/c03/cookie.jsp">返回</a>
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数学家是我理想

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值