【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. 流程
    【JavaEE】Cookie 和 Session_第1张图片

  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类的相关方法:
【JavaEE】Cookie 和 Session_第2张图片
① 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类中相关的方法:
    【JavaEE】Cookie 和 Session_第3张图片
    getAttribute、setAttribute都是键值对。

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

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

4. Cookie类中相关的方法:

Cookie类中相关的方法:
【JavaEE】Cookie 和 Session_第4张图片
Name不可以改,但Value可以改。


写一个模拟登录的案例

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

【JavaEE】Cookie 和 Session_第5张图片
【JavaEE】Cookie 和 Session_第6张图片

  • 这里的用户点击提交的时候,就会把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都是不同的)
    【JavaEE】Cookie 和 Session_第7张图片
    【JavaEE】Cookie 和 Session_第8张图片

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

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

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


上传文件

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

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

  1. Part类方法:
    【JavaEE】Cookie 和 Session_第10张图片

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

  3. 写一个实例:upload.html

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

① 通过form表单的方式上传文件,务必使用post方法。
② Enctype:按照特定的body格式来构造请求。
【JavaEE】Cookie 和 Session_第11张图片
82
参考代码:上传文件

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

  2. 在请求中会有:
    83

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


Servlet相关代码

pom.xml

具体的依赖可以修改

"1.0" encoding="UTF-8"?>
"http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    4.0.0

    org.example
    MessageWall
    1.0-SNAPSHOT

    
        8
        8
    

    
        
        
            javax.servlet
            javax.servlet-api
            3.1.0
            provided
        

        
        
            com.fasterxml.jackson.core
            jackson-databind
            2.13.4.2
        

        
        
            mysql
            mysql-connector-java
            5.1.49
        


    



web.xml

  1. 目录结构:
    【JavaEE】Cookie 和 Session_第12张图片

  2. 代码:

"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
        "http://java.sun.com/dtd/web-app_2_3.dtd" >

    Archetype Created Web Application


小结

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

【JavaEE】Cookie 和 Session_第13张图片

你可能感兴趣的:(Note-JavaEE,java-ee,servlet,服务器,上传文件,模拟登录)