cookie、session、Token区别

news2025/1/15 16:49:11

1 HTTP无状态,什么是无状态?

  • http 无法知道是哪个客户端发出的请求,也无法判断是否为已登录用户请求,这就导致了 http 无法记住用户的登录状态。

2 cookie和session的是什么?为什么session这么好还要用cookie?

  • cookie和session都是用来记录浏览器用户上下文状态信息。
    • cookie: 将用户上下文状态信息保存在客户端。
    • session:将用户上下文状态信息保存在服务端。
  • 虽然,session技术将用户状态信息维护在了服务器端,但是还是会用到cookie,主要是为了区分不同的用户,此时的cookie不在有用户的上下文状态信息只是单纯的用户身份标识SessionID.
  • cookie安全性不高,存在cookie欺骗,session相对来说安全性高一点,但是加重服务器的负担,安全性也不是绝对的,但我们访问一些不法网站的时候,非常容易遭到CSRF攻击,他会利用用户状态信息,发送不法请求。

3 Cookie一般存储些什么?

  • Cookie是一段不超过4KB的小型文本数据,由一个名称(Name)、一个值(Value)和其它几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。
  • Name/Value:设置Cookie的名称及相对应的值,对于认证Cookie,Value值包括Web服务器所提供的访问令牌。
  • Expires属性:设置Cookie的生存期。有两种存储类型的Cookie:会话性与持久性。
    • Expires属性缺省时,为会话性Cookie,仅保存在客户端内存中,并在用户关闭浏览器时失效;
    • 持久性Cookie会保存在用户的硬盘中,直至生存期到或用户直接在网页中单击“注销”等按钮结束会话时才会失效 。
  • Path属性:定义了携带Cookie可以访问的Web站点上的目录。
  • Domain属性:指定了可以访问该 Cookie 的 Web 站点或域。
  • Secure属性:指定是否使用HTTPS安全协议发送Cookie。
  • HTTPOnly 属性 :用于防止客户端脚本通过document.cookie属性访问Cookie。

Session一般存储些什么?

  • 用户身份验证信息:Session通常用于存储用户的身份验证状态,以便确定用户是否已登录或谁在访问应用程序。这包括用户的用户名、ID、角色等信息。

  • 会话标识符:每个会话通常都有一个唯一的会话标识符(Session ID),它可以存储在用户的Cookie中,也可以作为URL参数传递。会话标识符用于将用户与其对应的会话数据关联起来。

  • 用户偏好设置:应用程序可以使用Session来存储用户的个性化偏好设置,例如语言首选项、主题选择等。

  • 购物车信息:对于电子商务网站,Session通常用于存储用户的购物车内容,包括所选商品、数量和价格。

  • 临时数据:有时,应用程序需要在用户会话期间暂时存储数据,以便在不同页面之间传递信息。这可以包括表单数据、临时状态等。

  • 安全性相关信息:Session还可用于存储与安全性相关的信息,例如CSRF令牌(Cross-Site Request Forgery)或防止会话劫持的措施。

  • 登录时间和活动状态:Session可以用于跟踪用户的登录时间和活动状态,以便自动注销不活动的用户或实施安全措施。

4 跨域问题?如何解决?

在这里插入图片描述

  • 跨域请求:发送请求的页面地址,与请求访问的站点地址不一样。
  • 跨域问题:使用session保存用户上下文信息,以sessionId作为用户标识,这样同样会存在一个问题,那就是同源问题,当访问不法网站的时候,我们误点了一些弹窗或者隐藏在图片里面的跨域请求,这样会携带sessionId以及浏览器信息,正规网站误以为用户正常请求。导致跨域问题。
  • 解决方法:我们使用了Spring框架的@CrossOrigin注解来配置CORS策略。注解中的origins参数指定了允许访问这个接口的域名。这将限制只有https://example.com域名可以跨域访问 /api/data 接口。
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/api")
public class MyController {

    // 使用@CrossOrigin注解来配置CORS策略
    @CrossOrigin(origins = "https://example.com") // 允许https://example.com域名访问该接口
    @GetMapping("/data")
    public ResponseEntity<String> getData() {
        // 在这里处理您的请求逻辑
        return ResponseEntity.ok("Data from the server!");
    }
}

Token是什么?

  • Token是服务端生成的一串字符串,以作客户端进行请求的一个令牌,当第一次登录后,服务器生成一个Token便将此Token返回给客户端,以后客户端只需带上这个Token前来请求数据即可,无需再次带上用户名和密码。token其实说的更通俗点可以叫暗号,在一些数据传输之前,要先进行暗号的核对,不同的暗号被授权不同的数据操作。

为什么会出现Token

  • Cookie存储在客户端磁盘上,很容易被窃取,因此诞生了Sesssion+Cookie,但是会出现跨域问题,很容易遭受CSRF攻击,因此客户端Cookie设置了Domain属性,指定了可以访问该 Cookie 的 Web 站点或域。服务器端通过在Contoller层,使用@CrossOrigin注解来配置CORS策略,限制跨域访问,但是严格的跨域访问限制可能会导致一些问题:
    • 功能受限:如果跨域访问限制得太严格,可能会导致某些功能无法正常运作。例如,如果您限制了所有跨域请求,那么无法在您的网站上嵌入来自其他域的内容,如嵌入的地图、社交媒体分享等。
    • 跨域API访问问题:一些Web应用程序需要从不同的域请求数据或使用外部API,如社交媒体API或云服务API。如果不允许这些跨域请求,应用程序可能无法获得所需的数据,从而影响其功能。
  • 此外,Session存储在内存中,过多的Session造成服务器压力。
  • 因此,Token出现,Token只存在于HTTP脚本中,随HTTP脚本存入浏览器缓存。有因此不会被物理窃取,只会被拦截窃取,因此加密传输很重要。每次HTML页面点击按钮,发送下一个HTTP请求,HTTP会从父HTTP请求中获取Token。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/992630.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VR钢铁实训 | 铁前事业部虚拟仿真培训软件

随着科技的发展&#xff0c;虚拟现实技术在各个行业中的应用越来越广泛。在钢铁冶炼行业中&#xff0c;VR技术也逐渐得到了应用&#xff0c;其中铁前事业部虚拟仿真培训软件就是一项非常有优势的技术。 铁前事业部虚拟仿真培训软件是广州华锐互动打造的《钢铁生产VR虚拟培训系统…

MySQL的用户管理

1、MySQL的用户管理 &#xff08;1&#xff09;创建用户 create user zhang3 identified by 123123;表示创建名称为zhang3的用户&#xff0c;密码设为123123。 &#xff08;2&#xff09;了解user表 1&#xff09;查看用户 select host,user,authentication_string,select…

react memo判断刷新机制 自定义的比较函数 避免重复渲染

需求&#xff1a; 1. 需要在courseList参数变化时重新渲染组件。 2. 需要在currentWeekNumber参数 等于我指定值才重新渲染组件。 3.以上2个条件同时满足。 遇到的坑 一开始实现了我上面指定的问题需要的函数&#xff0c;后面发现怎么都刷新不了&#xff0c;经过深入观察发现m…

【ESP32】串口+wifi 透传,以及回调函数的使用

本文主要记录【ESP32】串口wifi 透传】的学习记录&#xff0c;主要包括 1.串口的AT 模式和透传模式 2. 串口命令解析 3. socket 连接 4. 回调函数的使用 【ESP32】串口wifi 透传&#xff0c;以及回调函数的使用 1. 函数接口说明2.开发环境3.硬件连接4.测试结果4.1发送 ATWS 命令…

Linux学习笔记-Ubuntu系统用户、群组、权限管理

一、概述 本文记录Ubuntu系统下通过命令操作用户账户进行管理。 Ubuntu系统版本&#xff1a; Linux ubuntu 5.15.0-1034-raspi #37-Ubuntu SMP PREEMPT Mon Jul 17 10:02:14 UTC 2023 aarch64 aarch64 aarch64 GNU/Linux 注&#xff1a;查看系统版本号的指令如下 uname -…

YOLOV7改进-针对小目标的NWD(损失函数)

link 1、复制这些 2、utils-loss&#xff0c;这里加 3、把这几行复制到utiils的loss.py 4、先对CoputerLoss类做修改 5、把那一行替换成这个 6、修改 7、iou_ration是超参&#xff0c;可以调&#xff0c;如果小目标比较多的话&#xff0c;这个值可以低一些&#xff0c;…

Vuex - state 状态(获取和使用共享数据)

文章目录 一、state是什么&#xff1f;二、state状态的作用三、如何使用store数据呢&#xff1f;使用数据的两种方式&#xff1a;1. 通过store 直接访问2. 通过辅助函数访问(简化) 一、state是什么&#xff1f; state是状态&#xff08;数据&#xff09; &#xff0c; 类似于v…

redis集群最少使用三个主节点的原因

集群最少三个主节点的原因 https://redis.io/docs/management/scaling/ 官网建议&#xff0c;搭建 redis 集群最少三主三从。 但是这么做是出于什么考虑呢&#xff1f; https://blog.csdn.net/qq_35549286/article/details/127057374 借鉴这位的解答 为什么是三个? cluster各…

骨传导与入耳式耳机哪种音质好?该如何选择?

骨传导耳机和传统耳机的定位不同&#xff0c;所以没有可比性&#xff0c;如果一定要说哪款耳机音质好&#xff0c;答案是入耳式耳机音质比较好&#xff01; 首先入耳式耳机是直接塞入耳朵佩戴&#xff0c;会最大程度减少漏音&#xff0c;同时不会改变音质&#xff0c;会直接传…

构建自定义美颜应用:全局美颜SDK的开发指南

美颜技术已经成为许多应用程序和平台的标配之一&#xff0c;为用户提供了改善外观的机会。为了在你的应用中提供自定义的美颜功能&#xff0c;你可以考虑使用全局美颜SDK。本文将向你介绍如何构建自定义美颜应用&#xff0c;以及开发全局美颜SDK的关键步骤和技巧。 一、明确需…

Revit SDK 介绍:RayTraceBounce 光线反弹

前言 这个例子模拟光线反弹。 内容 通过修改参数&#xff0c;从&#xff08;0&#xff0c;0&#xff0c;0&#xff09;点向&#xff08;1&#xff0c;0&#xff0c;0&#xff09;方向射出光线&#xff0c;经过若干次反弹之后的结果。如图所示&#xff1a; 在Revit API 中&…

通过 http-server 运行刚打包出来的脚手架项目

这里 我打包了自己的vue项目 react其实也一样 如果我直接 打开打包出来的 dist 下面的index.html 会出现白屏资源找不到 或者跨域等问题 这个问题其实配个nginx也能解决 但是其实如果只是想做个测试 nginx就太麻烦了 我们可以通过npm指令 全局安装一个http-server 终端执行 …

每日刷题|回溯法解决全排列问题第二弹之解决字符串、字母大小排列问题

食用指南&#xff1a;本文为作者刷题中认为有必要记录的题目 前置知识&#xff1a;回溯法经典问题之全排列 ♈️今日夜电波&#xff1a;带我去找夜生活—告五人 0:49 ━━━━━━️&#x1f49f;──────── 4:59 …

OpenRoads Designer道路旁添加公交车停车区

在道路工程建模时如果需要在路旁添加公交车停车区&#xff0c;如下图所示&#xff0c;可通过对道路轴线进行局部偏移的方式实现。 在道路旁添加如上图所示的公交车停车区操作步骤&#xff1a; 1、使用Geometry下的Single Offset Partial将路线中的一段进行偏移&#xff1a; 参数…

亚马逊、ManoMano等跨境电商平台测评还能做吗?

亚马逊测评是卖家通过真实购买商品并撰写评价来获取评价权利的过程 卖家账号发布产品后&#xff0c;测评买家账号进入商铺进行购买并对商品质量、外观、卖家服务态度和物流体验等方面进行点星留评 在亚马逊卖家运营中&#xff0c;评论是一个关键而必不可少的环节&#xff0c;…

本地起一个VUE 前端项目

#安装 安装 Vue CLI 3&#xff1a; Vue CLI是一个用于创建和管理Vue项目的命令行工具 npm install -g vue/cli#查看更详细的告警信息 npm install -g vue/cli --verbose#检查项目的依赖关系 ,保持项目的依赖关系最新和安全 npm audit npm audit fix#查看版本 vue --version#创建…

oled或数码管点阵的字模矩阵的原理讲解

通过取模软件得到的T字符的矩阵分析 字模选项中常用的设置的意义&#xff1a; **字宽和字高&#xff1a;**显示字符能够使用的长宽灯数量&#xff0c;也可以理解为像素 **点阵格式&#xff1a;**需要考虑实际焊接电路。阴码&#xff1a;灯共阴极&#xff0c;控制器输出高电位&…

Linux权限问题

文章目录 前言一、shell 命令1、什么是 shell?2、什么是 shell 脚本&#xff1f;3、shell环境4、总结 二、Linux权限1、su命令2、Linux文件类型3、Linux文件权限4、文件访问权限的相关设置4.1 chmod指令4.2 chown指令4.3 chgrp指令4.4 总结 前言 一、shell 命令 1、什么是 sh…

Android开发之lint代码检测编写和使用方法

文章目录 前言项目结构待检测项目lint检查器 依赖方式待检测项目lint检查器 代码编写方法调用检测Detector注册Detector编写 Toast硬编码检测Detector注册Detector编写 使用壳工程打包待检测项目使用kotlin代码java代码 AS识别结果kotlin代码java代码 命令行检测 参考文献 前言…

Fushion 360齿轮组制作教程

本教程总结 Kevin小哥的教程&#xff0c;原视频教程点击这里&#xff0c;笔者录制的教程视频见fushion 360齿轮制作 Fushion 360齿轮组制作教程 基本步骤添加齿轮工具相关设置绘制底板创建演示动画掏空较大的齿轮 视频教程及成品展示 基本步骤 添加齿轮工具 选择使用工具&…