Cookie:客户端会话技术,将数据保存到客户端,以后每次请求都携带Cookie数据进行访问。
name=zs
的数据存入Cookie对于Cookie的使用,我们更关注的应该是后台代码如何操作Cookie,对于Cookie的操作主要分两大类,本别是发送Cookie和获取Cookie,对于上面这两块内容,分别该如何实现呢?
3.1 发送Cookie
Cookie cookie = new Cookie("key","value");
response.addCookie(cookie);
3.2 获取Cookie
Cookie[] cookies = request.getCookies();
for
cookie.getName();
cookie.getValue();
对于Cookie的实现原理是基于HTTP协议的,其中设计到HTTP协议中的两个请求头信息:
set-cookie
cookie
Set-Cookie:username=zs
Set-Cookie
对应值username=zs
,并将数据存储在浏览器的内存中Cookie: username=zs
发送给服务端Cookie其实已经为我们提供好了对应的API来完成这件事,这个API就是setMaxAge(int seconds)
参数值为:
示例:
@WebServlet("/aServlet")
public class AServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//发送Cookie
//1. 创建Cookie对象
Cookie cookie = new Cookie("username","zs");
//设置存活时间 ,1周 7天
cookie.setMaxAge(60*60*24*7); //易阅读,需程序计算
//cookie.setMaxAge(604800); //不易阅读(可以使用注解弥补),程序少进行一次计算
//2. 发送Cookie,response
response.addCookie(cookie);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doGet(request, response);
}
}
这个时候,可以使用URL编码
,所以如果需要存储中文,就需要进行转码,具体的实现思路为:
1.在AServlet中对中文进行URL编码,采用URLEncoder.encode(),将编码后的值存入Cookie中
2.在BServlet中获取Cookie中的值,获取的值为URL编码后的值
3.将获取的值在进行URL解码,采用URLDecoder.decode(),就可以获取到对应的中文值