【计算机网络】Cookie、Session和上传文件重点知识汇总

简介: 【计算机网络】Cookie、Session和上传文件重点知识汇总

1.Cookie基础知识:

  1. Cookie是浏览器在本地持久化保存数据的一种方案
  2. 一个典型的使用场景:存储登录信息
  3. Cookie:是浏览器在本地存储数据(存放到硬盘上)的一种机制,cookie是请求头中的一个重要字段。每个Cookie都是一个键值对。
  4. cookie和query string一样都是程序员自定制的。Cookie是按照域名维度来组织的,不同的域名下有不同的Cookie,一个网站发起的http请求可能是来自于多个域名的。
  5. Cookie不是缓存,是持久化存储数据的手段,浏览器自动帮你存储,这个存储是保存到硬盘上的;而缓存的数据不一定是持久化的(也可以在内存里缓存);缓存的数据是用来提高访问速度的
  6. Cookie这里的键值对都是简单的字符串,只能存放一些简单的信息,例如:上次访问页面的时间,当前网页的访问次数,当前访问页面的身份信息(身份标识,id)等。
  7. Cookie从哪里来?Cookie是存在浏览器的本地,来源是服务器。上图中的这些Cookie都是浏览器访问了服务器之后由服务器返回的,在服务器返回的响应报文中,可以在响应header中包含一个或多个Set-Cookie这样的字段,浏览器看到这些Set-Cookie就会把这样的数据保存在浏览器本地
  8. Cookie到哪里去?来自于服务器,存储于浏览器,还要再返回到服务器。当浏览器保存了Cookie之后下次浏览器访问同一个网站,就会把之前本地存储的cookie再通过http请求header中的cookie给带回去。如果达到了过期时间,Cookie也会自动的被清除掉。
  9. 为什么要有这个一来一回,绕圈的过程呢?服务器要服务的客户端是很多的,这些不同的客户端应该要有不同的数据、只有返回了,服务器才知道客户端的详细情况。

2.Session基础知识:

  1. 服务器同一时刻收到的请求有很多,服务器需要清楚的区分每个请求属于哪个客户端,就需要先在服务器这里记录每个用户的身份标识和所对应的用户信息
  2. 会话的本质就是一个哈希表,存储着一些键值对。其中key就是身份标识(sessionId)value就是用户信息(session)
  3. sessionId是由服务器生成的一个唯一性字符串;和token是同一个东西的不同叫法。
  4. Cookie是在客户端的机制;Session是服务器的机制
  5. Servlet中的session默认是存储在内存上的,如果重启服务器则session数据就会丢失。

3.相关API:

在servlet中专门提供了相关的api,来操作Cookie和Session

3.1.HttpServletRequest类:

  1. 核心方法:
方法 说明
HttpSession getSession(false/true) 在服务器中获取会话,注意返回值
Cookie[ ] getCookies() 返回一个包含客户端发送请求的所有Cookie对象的数组,注意类型

  1. getSession方法的使用方式有俩种。第一种参数填写为false,判断当前的会话是否存在,如果不存在直接返回null;如果存在则返回对应的HttpSession对象第二种参数填写为true,判断当前会话是否存在,如果不存在就会创建一个新的键值对保存到哈希表中并把生成的sessionId返回到浏览器这里;如果存在则直接返回对应的HttpSession对象
  2. 判断当前会话是否存在是根据请求中的Cookie里的sessionId来查询哈希表
  3. getCookies方法直接把请求中的Cookie都获取到,Cookie本身也是键值对的结构。返回一个Cookie类型的数组。

3.2.HttpServletResponse类:

  1. 核心方法:
方法 说明
void addCookie(Cookie cookie) 把指定的cookie添加到响应中

  1. addCookie是返回响应,想给浏览器返回哪些Cookie都可以通过这个方法来添加,在这里添加的键值对都会体现在HTTP响应报文的Set-Cookie字段上

3.3.HttpSession类:

  1. 核心方法:
方法 说明
Object getAttribute() 返回指定名称的对象,如果没有指定名称的对象则返回null
void setAttribute() 使用指定的名称绑定一个对象到该会话中
boolean isNew() 判断当前对象是不是新创建出来的会话

  1. 一个HttpSession对象里面包含了多个键值对,我们可以往HttpSession中存任何我们需要的信息。

3.4.Cookie类:

  1. 核心方法:
方法 说明
String getName() 返回cookie的名称
String getValue() 获取于cookie关联的值
void setValue(String newValue) 设置于cookie关联的值

  1. 每个Cookie对象都是一个键值对。
  2. Http的Cookie字段中存储的是多组键值对,每个键值对在Servlet中都对应一个Cookie对象。

3.5.模拟实现登录页面

  1. 在登陆页面上用户可以填写用户名和密码;使用一个servlet来处理登录请求使用另外一个servlet来生成登陆成功后跳转的页面
  2. setAttribute可以灵活根据需求存储想要的东西(键值对)。
  3. 此处的会话是根据sessionId来查哈希表的。如果把浏览器存储的cookie删了并且不登陆直接访问index页面,会触发这个if,导致不能访问。如果没有登陆过直接访问主页也会提示!
  4. 登陆成功跳转的抓包情况:
  5. 登录页面创建会话和主页判断session存在:

处理登录请求的servlet:login

package login;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
//处理登录请求
@WebServlet("/login")
public class LoginServlet extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        req.setCharacterEncoding("utf8");
        //1.获取用户名和密码
        String username = req.getParameter("username");
        String password = req.getParameter("password");
        //2.验证密码是否正确
        //这里如果写成是user.equals("王大锤"),如果user是null,就会触发空指针异常
        //equals()在方法内部对参数为null做了特别处理,因此可以写成user.equals("王大锤")
        if("王大锤".equals(username) && "666".equals(password)){
            //登陆成功
            // a) 创建一个会话,用户刚登陆成功之前没有回话
            //getSession
            //  、创建session和一个Httpsession对象
            //  、把这俩个内容以键值对的形式插入到哈希表里
            //  、再把sessionId通过set-cookie发送给客户端
            HttpSession session = req.getSession(true);
            //随意设置键值对
            session.setAttribute("username","王大锤");
            // b) 让响应重定向到主页
            resp.sendRedirect("index");
        }else{
            //登陆失败
            resp.setStatus(403);
            resp.setContentType("text/html; charset=utf8");
            resp.getWriter().write("登陆失败!用户名或密码输入错误!!!");
        }
    }
}

生成登陆成功跳转主页的servlet:index

package login;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
//登陆成功之后跳转的页面
@WebServlet("/index")
public class IndexServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //首页中先获取了session,此处的session是刚才登录成功创建出来的
        //这里的参数是false,表示不新建,如果不存在返回null就行
        HttpSession session = req.getSession(false);
        if(session == null){
            resp.setStatus(403);
            resp.setContentType("text/html; charset=utf8");
            resp.getWriter().write("您尚未登录,不能访问主页!");
            return;
        }
        String username = (String) session.getAttribute("username");
        resp.setContentType("text/html;charset=utf8");
        resp.getWriter().write("欢迎来到主页," + username + "大哥请喝茶~");
    }
}

4.上传文件:

  1. 前端搭配form表单,form input type = ‘file”,允许通过浏览器选中一个文件上传给服务器。
  2. Servlet支持处理这种上传文件的请求,把这个请求的文件在后端获取到
  3. 每个文件就是一个Part对象。
  4. 核心方法:
方法 说明
Part getPart(String name) 获取请求中给定name的文件,和input标签的name属性一样(和getParameter类似)
Collection<Part> getParts() 获取所有的文件

  1. Part类方法:
方法 说明
String getSubmittedFileName() 获取提交的真实文件名
String getContentType() 获取提交文件的类型
long getSize() 获取文件的大小
void write(String path) 保存到指定路径

上传一个图片:

package upload;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
import java.io.IOException;
@WebServlet("/upload")
@MultipartConfig
public class UploadServlet extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Part part = req.getPart("myfile");
        System.out.println(part.getSubmittedFileName());
        System.out.println(part.getSize());
        System.out.println(part.getContentType());
        part.write("d:/idea/dada/result.jpg");
    }
}

如果对您有帮助的话,

不要忘记点赞+关注哦,蟹蟹

如果对您有帮助的话,

不要忘记点赞+关注哦,蟹蟹

如果对您有帮助的话,

不要忘记点赞+关注哦,蟹蟹

相关文章
|
18天前
|
缓存 Java Spring
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
文章比较了在Servlet和Spring Boot中获取Cookie、Session和Header的方法,并提供了相应的代码实例,展示了两种方式在实际应用中的异同。
78 3
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
|
1天前
|
存储 安全 数据安全/隐私保护
Cookie 和 Session 的区别及使用 Session 进行身份验证的方法
【10月更文挑战第12天】总之,Cookie 和 Session 各有特点,在不同的场景中发挥着不同的作用。使用 Session 进行身份验证是常见的做法,通过合理的设计和管理,可以确保用户身份的安全和可靠验证。
7 1
|
1月前
|
存储 缓存 数据处理
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
本文介绍了PHP会话控制及Web常用的预定义变量,包括`$_REQUEST`、`$_SERVER`、`$_COOKIE`和`$_SESSION`的用法和示例。涵盖了cookie的创建、使用、删除以及session的工作原理和使用,并通过图书上传的例子演示了session在实际应用中的使用。
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
|
1月前
|
存储 前端开发 Java
JavaWeb基础7——会话技术Cookie&Session
会话技术、Cookie的发送和获取、存活时间、Session钝化与活化、销毁、用户登录注册“记住我”和“验证码”案例
JavaWeb基础7——会话技术Cookie&Session
|
27天前
|
存储 安全 NoSQL
Cookie、Session、Token 解析
Cookie、Session、Token 解析
44 0
|
1月前
|
存储 JSON 数据安全/隐私保护
Cookie + Session 的时代已经过去了?
在探讨“Cookie + Session”这一经典组合是否已经过时的议题时,我们首先需要理解它们在Web应用认证和会话管理中的历史地位与当前面临的挑战。随着Web技术的飞速发展,特别是无状态服务、OAuth、JWT(JSON Web Tokens)等技术的兴起,这一传统机制确实面临了前所未有的变革压力。但说它“完全过去”或许过于绝对,因为它在特定场景下仍发挥着重要作用。
31 0
|
2月前
|
C# 开发者 Windows
WPF遇上Office:一场关于Word与Excel自动化操作的技术盛宴,从环境搭建到代码实战,看WPF如何玩转文档处理的那些事儿
【8月更文挑战第31天】Windows Presentation Foundation (WPF) 是 .NET Framework 的重要组件,以其强大的图形界面和灵活的数据绑定功能著称。本文通过具体示例代码,介绍如何在 WPF 应用中实现 Word 和 Excel 文档的自动化操作,包括文档的读取、编辑和保存等。首先创建 WPF 项目并设计用户界面,然后在 `MainWindow.xaml.cs` 中编写逻辑代码,利用 `Microsoft.Office.Interop` 命名空间实现 Office 文档的自动化处理。文章还提供了注意事项,帮助开发者避免常见问题。
173 0
|
4月前
|
存储 编解码 应用服务中间件
会话跟踪技术(Session 以及Cookie)
会话跟踪技术(Session 以及Cookie)
|
2月前
|
存储 JavaScript 前端开发
Cookie 反制策略详解:Cookie加解密原理、Cookie和Session机制、Cookie hook、acw_sc__v2、jsl Cookie调试、重定向Cookie
Cookie 反制策略详解:Cookie加解密原理、Cookie和Session机制、Cookie hook、acw_sc__v2、jsl Cookie调试、重定向Cookie
119 1
|
2月前
|
存储 安全 搜索推荐
【JavaWeb 秘籍】Cookie vs Session:揭秘 Web 会话管理的奥秘与实战指南!
【8月更文挑战第24天】本文以问答形式深入探讨了Web开发中关键的会话管理技术——Cookie与Session。首先解释了两者的基本概念及工作原理,随后对比分析了它们在存储位置、安全性及容量上的差异。接着,通过示例代码详细介绍了如何在JavaWeb环境中实现Cookie与Session的操作,包括创建与读取过程。最后,针对不同应用场景提供了选择使用Cookie或Session的指导建议,并提出了保障二者安全性的措施。阅读本文可帮助开发者更好地理解并应用这两种技术。
49 1