彼方尚有荣光在|

_xiaolin

园龄:2年9个月粉丝:3关注:5

Cookie

Cookie

1、Cookie

1、什么是Cookie?

1、Cookie翻译过来就是饼干的意思。
2、Cookiw是服务器通知客户端保存键值对的一种技术
3、客户端有了Cookie后,每次请求都发送给服务器
4、每个Cookie的大小不超过4kb
5、保存在客户端

2、如何创建Cookie?

image-20220531165936796

3、服务器如何获取Cookie?

服务器获取客户端的Cookie只需要一行代码:req.getCookies();

返回Cookies[]

4、Cookie值的修改

方案一:
1、先创建一个要修改的同名的Cookie对象
2、在构造器中同时赋予新的Cookie值
3、调用response.addCookie(Cookie);
// 方案一:
// 1、先创建一个要修改的同名的Cookie对象
// 2、在构造器中同时赋予新的Cookie值
Cookie cookie = new Cookie("key1","newvalue");
// 3、调用response.addCookie(Cookie);通知客户端,保存修改
resp.addCookie(cookie);
resp.getWriter().write("key1的cookie值修改成功");
方案二:
1、先查找需要修改的Cookie对象
2、调用setValue()方法赋予新的值
3、调用response.addCookie()通知客户端保存修改

5、Cookie生命控制

Cookie的生命控制指的是如何管理Cookie什么时候被销毁(删除)
setMaxage(int x)
x为正数:表示在指定的秒数后过期
x为负数:表示浏览器一关,Cookie就会被删除(默认值是-1
x为0:表示马上删除Cookie

6、免用户名登录

image-20220531181154591

Session

Session会话

1、什么是Session会话?

1、Session就是一个接口。
2、Session就是会话,它是用来维护一个客户端和服务器之间关联的一种技术
3、每个客户端都有自己一个Session会话。
4、Session会话中,我们经常用来保存用户登录后的信息。
5、保存在服务器端

2、如何创建Session和获取(id号,是否为新)

1、如何创建和获取Session,它们的API是一样的。
request.getSession()
*第一次调用是:创建Session会话
*之后调用都是:获取前面创建好的Session会话对象
2、isNew();判断到底是不是刚创建出来的(新的)
true 表示刚创建
false 表示获取之前创建的
3、每个会话都有一个身份证号,也就是id值,而且这个id值是唯一的
getId()得到Session会话的id

3、Session域数据的存取

/**
* 往session中保存数据
* @param req
* @param resp
* @throws ServletException
* @throws IOException
*/
protected void setAttribute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.getSession().setAttribute("name","lxg");
resp.getWriter().write("保存成功");
}
/**
* 往session中获取数据
* @param req
* @param resp
* @throws ServletException
* @throws IOException
*/
protected void getAttribute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String name = (String) req.getSession().getAttribute("name");
resp.getWriter().write("name:"+name);
}

4、Session生命周期控制

1public void setMaxInactiveInterval(int interval);
设置Session的超时时间(以秒为单位),超过指定时长,Session就会被销毁
值为正数,设置Session的超时时长
负数表示要不超时(很少使用)
2public int getMaxInactiveInteval()获取Session的超时时长
3、Session的默认超时时长是多少?
protected void defaultLife(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//获取session的默认生命周期
int maxInactiveInterval = req.getSession().getMaxInactiveInterval();
resp.getWriter().write("默认生命周期:"+maxInactiveInterval);
}
1800
因为Tomcat服务器的配置文件web.xml中默认以下的配置,就表示当前Tomcat服务器下所有的Session的超时配置默认时长是30分钟
<session-config>
<session-timeout>20</session-timeout>
</session-config>
4、如果说希望你的web工程,默认的Session的超时时长为其他时长,你可以在web.xml配置文件中去修改
5、如果只想修改个别的Session的超时时长就得使用上面的方法
session. setMaxInactiveInterval(int interval);单独设置超时时长。

image-20220531233543648

protected void life3(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//先获取Session对象
HttpSession session = req.getSession();
//设置session的生命周期
session.setMaxInactiveInterval(3);
resp.getWriter().write("设置生命周期成功");
}
6public void invalidate()让当前的Session马上失效
protected void deleteNow(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//获取session
HttpSession session = req.getSession();
//删除session
session.invalidate();
resp.getWriter().write("删除session成功");
}

5、浏览器和Session之间关联的技术内幕

Session技术,底层其实是基于Cookie技术来实现的。

image-20220531235213238

本文作者:_xiaolin

本文链接:https://www.cnblogs.com/SilverStar/p/17415176.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   _xiaolin  阅读(6)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起