Cookie
Cookie是什么
cookie其实是一些数据信息,类型为“小型文本文件”,存储在电脑的文本文件上。是一种浏览器支持的本地存储机制,有服务器创建,在响应请求时自动存储在浏览器中。
Cookie有什么用
cookie是为了辨别用户身份的。由于HTTP本身是无状态的协议,服务端不会记得是谁向它发来的请求。但是在某些情况下我们需要记得用户在未登录的状态下浏览了什么,比如是否记住密码等等。这个时候需要cookie。如果服务器需要记录用户状态,服务器会在响应信息中包含一个Set-Cookie的响应头,客户端会根据这个响应头存储Cookie信息。再次请求服务器时,客户端会在请求信息中包含一个Cookie请求头,而服务器会根据这个请求头进行用户身份、状态等较验。
Cookie的表示
一般情况下,cookie是以键值对进行表示的(key-value),例如name=jack,这个就表示cookie的名字是name,cookie携带的值是jack。
Cookie的生命周期
cookie有两种存储周期一种是会话性,一种是持久性。
- 会话性:cookie仅会保存在客户端的内存中,关闭客户端cookie失效
- 持久性:cookie保存在用户的硬盘里面,直至生存周期结束
Cookie的使用方法
java中
* new Cookie(String name,String value)
创建一个cookie对象 必须传入cookie的名字和cookie的值
* getValue():
得到cookie保存的值
*getName():
得到cookie的名称
setMaxAge(int expiry):
设置cookie的有效期,默认为-1。这个如果设置负数,表示客服端关闭,cookie就会删除。0表示马上删除。正数表示有效时间,单位是秒。
setPath(String uri):
设置cookie的作用域
HttpServletRequest和HttpServletResponse对cookie进行操作的方法
response.addCookie(Cookie cookie):将cookie给客户端进行保存
resquest.getCookies():得到客服端传过来的所有cookie对象
Cookie的获取
Cookie的获取可以通过HttpServletRequest的getCookie方法,方法返回对象的数组。
对数组进行循环,调用cookie的getName方法,可以遍历所有cookie的值。
// 得到所有的cookie
Cookie[] cookies = request.getCookies();
//对所有的cookie进行遍历
for(Cookie cookie:cookies){
if(cookies.getName().equals("LoginAct")
String LoginAct = cookie.getvalue();
} if(cookies.getName().equals("LoginPwd")){
String Loginpwd = cookie.getvalue();
}
2.EL表达式(页面获取动态数据)
${cookie.LoginAct.value}
${cookie.LoginPwd.value}
总结:
Cookie就是一些数据,用于存储服务器返回给客服端的信息,客户端进行保存。在下一次访问该网站时,客户端会将保存的cookie一同发给服务器,服务器再利用cookie进行一些操作。利用cookie我们就可以实现自动登录,保存游览历史,身份验证等功能。