【JavaEE】Cookie和Session-创新互联

努力经营当下,直至未来明朗!

目前成都创新互联公司已为千余家的企业提供了网站建设、域名、网络空间、网站托管、企业网站设计、兰溪网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。文章目录
  • 【Cookie和Session】
  • 相关方法
    • 1. HttpServletRequest类的相关方法
    • 2. HttpServletRespon类的相关方法
    • 3. HttpSession类中相关的方法:
    • 4. Cookie类中相关的方法:
  • 写一个模拟登录的案例
  • 上传文件
  • Servlet相关代码
    • pom.xml
    • web.xml
  • 小结


坚持一定很酷!

【Cookie和Session】
  1. Cookie是浏览器在本地持久化保存数据的一种方案。

  2. Cookie一个典型的使用方式就是存储登录信息。

  3. 流程
    60

  4. Cookie在浏览器中工作,Session是在服务器这边工作的。

  5. Cookie 和 Session 的区别:

① Cookie 是客户端的机制,Session 是服务器端的机制.。
② Cookie 和 Session 经常会在一起配合使用,但是不是必须配合。

  • 完全可以用 Cookie 来保存一些数据在客户端,这些数据不一定是用户身份信息,也不一定是token / sessionId
  • Session 中的 token / sessionId 也不需要非得通过 Cookie / Set-Cookie 传递.

相关方法

在Servlet中也提供了相关的API让我们来操作Cookie和Session,以下介绍核心方法:

1. HttpServletRequest类的相关方法

HttpServletRequest类的相关方法:
70
① HttpSession getSession(参数);

① 如果参数为false,判定当前会话是否存在,如果不存在直接返回null;存在则返回对应的HttpSession对象。
② 如果参数为true,判定当前会话是否存在,如果不存在就创建一个新的键值对并保存到哈希表中,然后把生成的sessionId(身份标识)返回到浏览器这里;存在则返回对应的HttpSession对象。

② getCookies(); 直接把请求中的Cookie都获取到,Cookie本身也是键值对结构,可以通过getName()、getValue()来获取。请求里的Cookie可能有多组键值对,直接使用Cookie类型的数组表示。

2. HttpServletRespon类的相关方法

HttpServletRespon类的相关方法:
61

① addCookie(); 返回响应,你想给浏览器返回哪些cookie都可以通过该方法进行添加。
(可以手动构造cookie对象,需要name、value)
② 在这里添加的键值对都会体现在HTTP响应报文的SetCookie字段上。

3. HttpSession类中相关的方法:
  1. HttpSession类中相关的方法:
    62
    getAttribute、setAttribute都是键值对。

  2. HTTP这块所涉及到的键值对:

① query string
② 请求/响应中的header
③ Cookie里的内容
④ form表单里提交的body
⑤ json格式的body
⑥ 服务器存储若干个sessionId和HttpSession对象
⑦每个HttpSession对象本身里面又可以保存多个键值对,方便程序员自定义存储的数据。

4. Cookie类中相关的方法:

Cookie类中相关的方法:
63
Name不可以改,但Value可以改。


写一个模拟登录的案例
  1. 登录页面:用户可以填写用户名+密码
  2. Servlet来处理登录请求
  3. 使用另一个Servlet来生成主要内容(登录成功后跳转到的页面)

65
66

  • 这里的用户点击提交的时候,就会把input框里的name作为key,把input框里用户的输入作为value,然后把这个键值对放到body中提交给服务器。
  • 此处的name属性决定了键值对的键,也就决定了服务器这边的getParameter怎么写。

67

提交form必须得有一个submit这样的标签。

  1. userName.equals(“xxx”); 这样写如果在userName是null的时候会触发空指针异常;所以一般写为”xxx”.equals(userName);的形式,”xxx”是字符串常量,肯定不会出现空指针异常。(equals在方法内部对参数null单独进行处理了)

  2. 如果后期我们需要调用同事写的方法时,一般是自己判空+提醒同事判空 =》 double check

  3. 响应中的Set-Cookie:通过getSession操作创建会话的同时生成sessionId,并且把这个sessionId通过set-Cookie返回给浏览器,浏览器收到的请求中就会带有Cookie,其存储的就是sessionId。(每个sessionId都是不同的)
    70
    71

  4. 如果想要让响应跳转到某个页面,得使用sendRedirect重定向报文。

  5. SetAttribute方法根据需求想存啥就存啥。

  6. 会话默认是保存在内存中的,一重启服务器就会重置数据。
    10.参考代码:登录+跳转


上传文件
  1. 前端搭配form表单。form中: input type=”file” ,允许通过浏览器选中一个文件上传给服务器。
  2. Servlet就支持处理这种上传文件的请求,把这个请求到的文件在后端进行获取。
  3. HttpServletRequest 类方法:
    72

① Part getPart(String name) ; 参数name就是input标签中的name属性(和getParameter类似)
② Part表示一个文件。一次上传可以包含多个文件(可以有多个input type=”file”),每个文件都是一个Part对象。

  1. Part类方法:
    77

  2. 注:下载文件的话就只要将返回的Content-Type设置为一些类型就行,如zip。

  3. 写一个实例:upload.html

上传文件方法必须是post!
80

① 通过form表单的方式上传文件,务必使用post方法。
② Enctype:按照特定的body格式来构造请求。
81
82
参考代码:上传文件

  1. 各大网站中,比如上传个简历、图片等都是类似的操作。

  2. 在请求中会有:
    83

① Content-Type: multipart/form-data; 使用form上传图片专属类型。
② boundary=----WebKitFormBoundaryXpoLUU0oPzGr2Shp
边界:后面是浏览器随机生成的字符串,在body的始末位置会出现,作为分隔符使用。


Servlet相关代码 pom.xml

具体的依赖可以修改

4.0.0org.exampleMessageWall1.0-SNAPSHOT88javax.servletjavax.servlet-api3.1.0providedcom.fasterxml.jackson.corejackson-databind2.13.4.2mysqlmysql-connector-java5.1.49

web.xml
  1. 目录结构:
    1

  2. 代码:

Archetype Created Web Application

小结
  1. Cookie和Session的相关方法
  2. Cookie和Session的流程
  3. 模拟登录(页面跳转)
  4. 上传文件
  5. Servlet相关代码片段

yyy

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


分享标题:【JavaEE】Cookie和Session-创新互联
地址分享:http://myzitong.com/article/cscopi.html