我的编程空间,编程开发者的网络收藏夹
学习永远不晚

WEB核心【会话技术】第十五章

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

WEB核心【会话技术】第十五章

目录

  • 💂 个人主页: 爱吃豆的土豆
  • 🤟 版权: 本文由【爱吃豆的土豆】原创、在CSDN首发、需要转载请联系博主
  • 💬 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦
  • 🏆人必有所执,方能有所成!

  • 🐋希望大家多多支持😘一起进步呀!

1,会话技术

        1.1,简述及分类

        1.2,浏览器端会话技术-cookie【阶段重点】

                1.2.1:简述&入门

                1.2.2:注意事项

                1.2.3:持久化

                1.2.4:有效路径        

                1.2.5:唯一标识


1,会话技术

        1.1,简述及分类

会话:一个客户端(浏览器)与Web服务器之间连续发生的一系列请求和响应过程会话技术:用来保存会话过程中产生的数据

会话技术:

保存在浏览器的会话技术---Cookie

保存在服务器的会话技术---Session

会话开启:浏览器开启,第一次访问服务器

会话关闭:浏览器关闭

        1.2,浏览器端会话技术-cookie【阶段重点】

                1.2.1:简述&入门

Cookie是由服务器进行编写、读取

Cookie是由浏览器进行保存

Cookie传递中,cookie是k=v键值对方式传递。

依赖请求头Cookies 、响应头Set-Cookie

 

 

 

public void run1(){    //1、服务器端创建cookie对象,key value   ,key和value必须是String    Cookie c1 = new Cookie("k1", "v1");    Cookie c2 = new Cookie("k2", "v2");    //2、将cookie追加到响应头    HttpServletResponse response = getResponse();    response.addCookie(c1);    response.addCookie(c2);

 

请求头中有cookie信息:

 

上述方法若获取不到cookie,就会返回Null

public void run2(){    //1、获取request对象    HttpServletRequest request = getRequest();    //2、读取cookie信息,每个cookie是一个cookie对象,多个cookie是一个cookie[]    Cookie[] arr = request.getCookies();    //3、遍历数组,每遍历一个cookie对象。 通过getName获取key   通过getValue获取value    if(arr!=null){        for (Cookie cookie : arr) {            System.out.println(cookie.getName()+"="+cookie.getValue());        }    }}

注意:

  1. 关闭服务器,不会影响浏览器保存的cookie
  2. 关闭浏览器(会话技术),会导致自定义保存的cookie失效(临时cookie)

小结:

Cookie是由服务器编写、读取

Cookie是由浏览器保存

                1.2.2:注意事项

 

一次性不能向前端写出过多cookie

Cookie不要滥用,否则会导致新cookie数据无法保存问题。

3,

public static void main(String[] args) throws UnsupportedEncodingException {    String str = "小张";    String encode = URLEncoder.encode(str, "utf-8");    System.out.println(encode);//%E5%B0%8F%E5%BC%A0    String decode = URLDecoder.decode(encode, "utf-8");    System.out.println(decode);//小张}
public void run4() throws UnsupportedEncodingException {    Cookie c = new Cookie("k3", URLEncoder.encode("小张","utf-8"));    getResponse().addCookie(c);}

 

public void run5() throws UnsupportedEncodingException {    //1、获取request对象    HttpServletRequest request = getRequest();    //2、读取cookie信息,每个cookie是一个cookie对象,多个cookie是一个cookie[]    Cookie[] arr = request.getCookies();    //3、遍历数组,每遍历一个cookie对象。 通过getName获取key   通过getValue获取value    if(arr!=null){        for (Cookie cookie : arr) {            System.out.println(cookie.getName()+"="+ URLDecoder.decode(cookie.getValue(),"utf-8"));        }    }}

Cookie:不能直接存中文,会报非法参数异常,可以使用URL编码存储cookie,可以使用URL解码从cookie取出中文信息 

                1.2.3:持久化

 

  1. 持久化cookie

 

public void run6(){    //1、创建cookie对象    Cookie c = new Cookie("k4", "v4");    //2、设置存活时间 (≥0  持久化cookie    -1 临时cookie)    c.setMaxAge(60);//60秒    //3、添加响应头    getResponse().addCookie(c);}

小结:

持久化cookie,不以浏览器关闭而销毁cookie,以cookie过期来销毁cookie。

持久化cookie传递时:

Set-Cookie:k=v;到期时间;

 2、cookie立即过期(删除cookie)

public void run7(){    //1、创建cookie对象    Cookie c = new Cookie("k5", "v5");    //2、立刻销毁    c.setMaxAge(0);    //3、添加响应头    getResponse().addCookie(c);}

解析:向浏览器写出一个k5=v5 cookie,该cookie在1970年1月1号就过期(早就过期了)

注意:

SetMaxAge(0); 立刻过期,立刻销毁(删除某个cookie)

 

3、删除某个cookie

默认情况下:cookie名称如果相同,就会新的键值对覆盖旧的键值对。

第一次执行:k1=v1;过期时间是2021/7/1 17:45:00

第二次执行:k1=v3;过期时间是2021/7/2 17:45:00

浏览器保存的是k1=v3;过期时间是2021/7/2 17:45:00

若我们设置了一个cookie,该cookie是7天后才过期。

若需要删除该cookie,只需要服务器重新设置该cookie有效时间为0.


public void run8(){
    Cookie c = new Cookie("k8", "v8");
    c.setMaxAge(60*60*24*7);//7天
    getResponse().addCookie(c);
}


public void run9(){
    Cookie c = new Cookie("k8", "");
    c.setMaxAge(0);//立刻销毁
    getResponse().addCookie(c);
}

小结:如果我们需要删除某个cookie,默认情况下,需要cookie名和待删除cookie的名字保持一致,setMaxAge(0),写出响应头,即可覆盖原先在浏览器保存的cookie,该cookie会立刻过期销毁,达到删除cookie的目的。

                1.2.4:有效路径     

   

浏览器:

C1:   /项目名/aaa/

C2:   /项目名/bbb/

C3:   /项目名/aaa/bbb/

访问路径:

http://localhost:8080/项目名/ 没有cookie发给服务器

http://localhost:8080/项目名/aaa/1.html c1被发给服务器

http://localhost:8080/项目名/aaa/bbb/1.html c1和c3被发给服务器

http://localhost:8080/项目名/bbb/1.html c2被发给服务器

 

两种常见设置方式:

  1. 当前服务器可用cookie:  setPath("/");    http://localhost:8080/
  2. 当前项目某个模块cookie:setPath("/项目名/模块名/");

setPath("/p1/user/");   http://localhost:8080/p1/user/

setPath("/p1/product/");   http://localhost:8080/p1/product/

 

public void run10(){    Cookie c1 = new Cookie("c1", "v1");    Cookie c2 = new Cookie("c2", "v1");    Cookie c3 = new Cookie("c3", "v1");    //设置有效路径    c1.setPath("/day10_1/aaa/");    c2.setPath("/day10_1/bbb/");    c3.setPath("/day10_1/aaa/bbb/");    getResponse().addCookie(c1);    getResponse().addCookie(c2);    getResponse().addCookie(c3);}

                1.2.5:唯一标识

 

public void run11(){    Cookie a1 = new Cookie("a1", "v1");    Cookie a2 = new Cookie("a1", "v2");    //a1.setDomain();//设置域名    a1.setPath("/day10_1/aaa/");    a2.setPath("/day10_1/bbb/");    getResponse().addCookie(a1);    getResponse().addCookie(a2);}

 

如果唯一标识都相同:两个cookie相互覆盖,新cookie覆盖旧cookie

如果唯一标识不相同:两个cookie分别保存,互不影响

补充:

有效路径认知:

如果当前servlet的访问路径是:

http://localhost:8080/day10_1/aaa/bbb/d1?method=run1

若该servlet设置cookie,没有手动给予有效路径,有效路径默认为当前目录:

/day10_1/aaa/bbb/

来源地址:https://blog.csdn.net/m0_64550837/article/details/125380628

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

WEB核心【会话技术】第十五章

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

达梦数据携手第十三届数据库技术大会共话数据库技术未来

12月14~16日,第13届中国数据库技术大会(DTCC2022)于线上举行。武汉达梦数据库股份有限公司(以下简称\"达梦数据)作为国内领先的数据库产品开发商,重磅亮相此次行业盛会。达梦数据江苏子公司总经理付新和达梦数据技术总监黄海明,应邀分
达梦数据2024-12-01

打造银行核心全栈国产化新模式,第三届数字金融技术创新与应用研讨会成功举办

为了加快数字金融发展,推动金融信创能力提升与生态建设,服务金融机构数字化转型,3月28日,“数金游学”走进杭州银行——金融科技创新论坛(第 19 期)暨第三届数字金融技术创新与应用研讨会成功举办。本次活动由“科创中国”金融科技产业服务团、中
银行核心2024-11-30

编程热搜

目录