之前已经学习完了Javaweb之前端三剑客,JQuery,servlet,xml,等一系列内容,接下来学习Cookie和Session了,
一、Cookie(饼干)
1、什么是Cookie
- cookie是服务器通知客户端保存键值对的一种技术
- 客户端有了cookie后,每次请求都发送给服务器。
- 每个cookie的大小不能超过4kb
2、如何创建cookie
(1) 首先创建项目
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="pragma" content="no-cache" />
<meta http-equiv="cache-control" content="no-cache" />
<meta http-equiv="Expires" content="0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Session</title>
<base href="http://localhost:8080/13_cookie_session/">
<style type="text/css">
ul li {
list-style: none;
}
</style>
</head>
<body>
<iframe name="target" width="500" height="500" style="float: left;"></iframe>
<div style="float: left;">
<ul>
<li><a href="sessionServlet?action=createOrGetSession" target="target">Session的创建和获取(id号、是否为新创建)</a></li>
<li><a href="sessionServlet?action=setAttribute" target="target">Session域数据的存储</a></li>
<li><a href="sessionServlet?action=getAttribute" target="target">Session域数据的获取</a></li>
<li>Session的存活</li>
<li>
<ul>
<li><a href="sessionServlet?action=defaultLife" target="target">Session的默认超时及配置</a></li>
<li><a href="sessionServlet?action=life3" target="target">Session3秒超时销毁</a></li>
<li><a href="sessionServlet?action=deleteNow" target="target">Session马上销毁</a></li>
</ul>
</li>
<li><a href="" target="target">浏览器和Session绑定的原理</a></li>
</ul>
</div>
</body>
</html>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="pragma" content="no-cache" />
<meta http-equiv="cache-control" content="no-cache" />
<meta http-equiv="Expires" content="0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Cookie</title>
<base href="http://localhost:8080/13_cookie_session/">
<style type="text/css">
ul li {
list-style: none;
}
</style>
</head>
<body>
<iframe name="target" width="500" height="500" style="float: left;"></iframe>
<div style="float: left;">
<ul>
<li><a href="cookieServlet?action=createCookie" target="target">Cookie的创建</a></li>
<li><a href="cookieServlet?action=getCookie" target="target">Cookie的获取</a></li>
<li><a href="cookieServlet?action=updateCookie" target="target">Cookie值的修改</a></li>
<li>Cookie的存活周期</li>
<li>
<ul>
<li><a href="cookieServlet?action=defaultLife" target="target">Cookie的默认存活时间(会话)</a></li>
<li><a href="cookieServlet?action=deleteNow" target="target">Cookie立即删除</a></li>
<li><a href="cookieServlet?action=life3600" target="target">Cookie存活3600秒(1小时)</a></li>
</ul>
</li>
<li><a href="cookieServlet?action=testPath" target="target">Cookie的路径设置</a></li>
<li><a href="" target="target">Cookie的用户免登录练习</a></li>
</ul>
</div>
</body>
</html>
(2)创建cookie
- 导入这个baseServlet
public abstract class BaseServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 解决post请求中文乱码问题
// 一定要在获取请求参数之前调用才有效
req.setCharacterEncoding("UTF-8");
String action = req.getParameter("action");
try {
// 获取action业务鉴别字符串,获取相应的业务 方法反射对象
Method method = this.getClass().getDeclaredMethod(action, HttpServletRequest.class, HttpServletResponse.class);
// System.out.println(method);
// 调用目标业务 方法
method.invoke(this, req, resp);
} catch (Exception e) {
e.printStackTrace();
}
}
}
- 创建CookieServlet
- 创建cookie
- 可以再次运行即可发现报错
- 然后就可以查看了
- 这里乱码了
- cookie创建流程
- 这样可以保存在Redis里面,然后客户端每次请求都会携带上这个cookie,然后发起请求的时候就不用每次都登录再访问了。
(3)后端如何获取cookie
- Cookie工具类
- 为什么能获取cookie呢?
- 获取某一个特定的cookie,是没有提供获取某一个cookie的,而是要进行遍历的时候进行判断。
```java
public class CookieUtils {
/**
* 查找指定名称的 Cookie 对象
* @param name
* @param cookies
* @return
*/
public static Cookie findCookie(String name , Cookie[] cookies){
if (name == null || cookies == null || cookies.length == 0) {
return null;
}
for (Cookie cookie : cookies) {
if (name.equals(cookie.getName())) {
return cookie;
}
}
return null;
}
}
(4)如何修改cookie
- 先创建一个要修改的同名(指的key)的cookie对象
- 在构造器,同时富裕新的cookie值
- 调用response.addCookie(newCookie)
- 另外一种方式
3、浏览器查看cookie
这个很简单,就不用说了
4、Cookie生命控制
5、Cookie有效路径Path的设置
- path路径能干嘛
- Cookie的path属性可以有效的过滤哪些cookie可以发送给服务器,哪些不发
- path属性是通过请求的地址来进行有效的过滤
6、Cookie实现面用户名登录
- 编写jsp页面
- 编写Servlet
二、Session
1、什么是Session会话
- Session就一个接口(HTTPSession)
- Session就是会话,它是用来维护一个客户端和服务器之间关联的一种技术
- 每个客户端都有自己的Session会话
- Session会话中,我们经常用来保存用户登录之后的信息
2、如何创建Session和或者(ID号,是否更新)
- 如何创建
request.getSession()第一次调用就是创建,第二次调用就是获取 - isNew();可以判断是否到底刚创建出来的(true就是刚创建的)
3、获取Session域数据的存取
4、Session生命周期
- 可以设置超时时间:public void setMaxInactiveInterval(int interval) 设置 Session 的超时时间(以秒为单位),超过指定的时长,Session就会被销毁。
- 值为正数的时候,设定 Session 的超时时长。
- 负数表示永不超时(极少使用)
- public int getMaxInactiveInterval()获取 Session 的超时时间
- public void invalidate() 让当前 Session
- Session默认的超时时间为30min,因为在Tomcat服务器的配置文件web.xml中默认有配置
小结:如果你想个别的修改session的修改超时时间,就可以使用方法进行修改,如果全部修改的话就修改配置文件
5、浏览器和Session之间关联的技术内幕