会话技术–Cookie
1.引入会话的原因:因为http协议是无状态的,所以在每个客户访问服务器资源时,服务器无法识别客户端,所以需要使用会话技术识别客户端的状态。引入会话技术就是帮助服务器去区分客户端。
2.一次会话:从打开一个浏览器访问某个web站点,到关闭该浏览器的过程就是一个会话。会话技术记录了这次会话中客户端的状态和数据。
3.会话技术:会话技术访问Cookie和Session。
Cookie会话技术
1.什么是Cookie
Cookie在浏览器与服务器中的传输过程:
1.当第一次浏览器访问服务端时,cookie不存在;
2.在访问的资源中如果有共享的数据,那么服务端将创建一个cookie对象,将数据保存到该cookie对象中;
3.服务器将在响应的消息中增加set-Cookie头字段,响应携带着cookie数据保存到浏览器中;
4.当浏览器再次访问该服务器时,都会在请求信息中将保存的数据以cookie的形式发送给服务器。这样服务器就能知道是当前的请求时由那个用户发出的。
Cookie技术就是将用户的信息保存到浏览器的一个技术,当下次访问时,浏览器将会自动携带cookie的信息过去服务端。
2.学习cookie
从上面的分析可以知道,学习cookie主要分为两个部分:一是在服务端中产生cookie,并将其发送给客户端;二是服务器从客户端中接收携带的cookie
2.1服务器向客户端发送一个cookie
1.创建一个cookie
Cookie cookie = new Cookie(String cookieName,String cookieValue);
注:在cookie中不能存储中文
2.设置Cookie的持久化
Cookie对象创建出来默认是会话级别的(即会话结束就销毁),如果设置了持久化时间,那么,cookie信息将会被持久化到浏览器的磁盘文件中。过了持久化时间后浏览器自动删除该cookie的信息。
cookie.setmaxAge(秒);
3.设置Cookie的携带路径
cookie.setPath(String path)
注:如果不设置携带路径,那么cookie信息会在访问产生该cookie的web资源所在的路径到携带cookie信息;设置了携带路径,那么cookie信息会在访问设置的路径资源时才会携带,其他路径不会携带。
4.向客户端发送cookie
response.addCookie(Cookie cookie)
注:cookie会以响应头的形式发送给客户端。
注:如果想删除客户端已经存储的cookie信息,那么就使用同名同路径的持久化时间为0的cookie进行覆盖即可。
2.2服务端接收客户端携带的cookie
1.通过request获得所有的Cookie
Cookie[] cookies = request.getCookies();
2.遍历Cookie数组,通过Cookie的名称获得需要的Cookie
for(Cookie cookie:cookies){
if(cookie.getName.equal(cookieName)){
String cookieValue=cookie.getValue();
}
}
注:cookie信息是以请求头的方式发送到服务端的