彼方尚有荣光在|

_xiaolin

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

Cookie

Cookie

1、Cookie

1、什么是Cookie?

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

2、如何创建Cookie?

图片转存失败,建议将图片保存下来直接上传

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、免用户名登录

图片转存失败,建议将图片保存下来直接上传

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生命周期控制

1、public void setMaxInactiveInterval(int interval);
设置Session的超时时间(以秒为单位),超过指定时长,Session就会被销毁
    值为正数,设置Session的超时时长
    负数表示要不超时(很少使用)
2、public 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);单独设置超时时长。 

图片转存失败,建议将图片保存下来直接上传

protected void life3(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
   //先获取Session对象
    HttpSession session = req.getSession();
    //设置session的生命周期
    session.setMaxInactiveInterval(3);
    resp.getWriter().write("设置生命周期成功");
} 
6、public 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技术来实现的。 

图片转存失败,建议将图片保存下来直接上传

本文作者:_xiaolin

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

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

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