如何让Java项目兼容更多的客户端设备(一)

news2024/11/26 2:26:40

如何让Java项目兼容更多的客户端设备(一)

引入

HTTP访问是无状态的,(服务器不知道是不是你访问的)所以我们不知道每次登录的是谁

如果想实现每次登录不用重复登录,最简单的就是让浏览器记住用户名和密码。但这样做风险极大,如果电脑被黑了就会泄露出去密码;而且每次浏览器都要想办法在请求里加入用户名和密码


cookie:让HTTP请求都自动带数据给服务器的技术

cookie基本流程

浏览器发送一个HTTP请求过去后,第一次cookie是空的,然后服务器会set cookie里两个重要的值name 和 value并发送回去,这样浏览器每次访问这个网站的时候把cookie带过去即可。

在这里插入图片描述

说白了Cookie就是一种存储在浏览器的数据而已。打开浏览器就可以看到保存了那些的Cookie的,只要电脑被黑在cookie里的重要信息就很容易被泄露。

Cookie的核心特点:每个请求,都会自动发送Cookie到相应的服务器那里


Session (会话)

浏览器和服务器是在进行会话的,浏览器访问服务器就是会话的开始,但关掉网页并不一定会话的结束。(比如你很可能误触)因此不同的网站对每个用户的会话都设定了时间(会话的结束时间)和唯一的ID(Session ID)这是服务器自己定义的东西,所以一般会保存在数据库里面。
在这里插入图片描述

Session ID是没有规律的字符串,之所以不是用用户名而是Session ID就是出于安全考虑。而且服务器在发送Cookie之前是会对这个含有Session ID的Cookie进行签名,如果黑客修改了ID,其就会变成服务器识别不了的字符串。

会话的结束,等Cookie的有效期结束后,浏览器一般会自行删除这个Cookie。失效后就要重新输入用户名和密码了


JSON Web Token

  • 引入

当用户量过大的时候,服务器就会面临可能需要存储大量的ID在服务器里,如果有多台服务器,一台服务器存储了ID后就要分享ID给其他服务器(避免超载)。但是如果更多的话就要让数据库存储ID了,但如果数据库崩溃了,又会影响服务器获取Session ID.

  • 过程
    在这里插入图片描述

浏览器把JWT以Cooike或者Storage的形式进行存储

这和Session很类似,只不过Token存储在用户那边了

服务器不需要存储,服务器只管签发和验证所有人的签名都是一个 只要存一个就行了

换句话说,jwt是不用放内存的,session是要在内存的,节省了内存

这样服务器就不需要存储凭证了 跟session不一样,jwt只存储在客户端

sion是要在内存的,节省了内存**

这样服务器就不需要存储凭证了 跟session不一样,jwt只存储在客户端

相当于服务器只存储了一个解密工具,浏览器把信息加密发送给客户端,然后服务器收到请求再通过解密看服务器保存的密码是否配对解密出来的密码

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

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

相关文章

球面距离计算方式(杭州到各城市的球面距离计算球面距离)

1)杭州到各城市的球面距离 1、数据来源:自主计算 2、时间跨度:至今 3、区域范围:368个城市 4、指标说明:利用城市经纬度,计算球面距离 部分数据如下: (2)计算两个点之…

Sentinel配置持久化到Nacos实现流控熔断

控制台 jar 下载:github.com/alibaba/Sen… 启动参数 # 将控制台自身接入到sentinel nohup java -jar -Dproject.namesentinel-dashboard -Dcsp.sentinel.dashboard.serverlocalhost:8181 sentinel-dashboard-1.8.5.jar --server.port8181 &> sentinel.log …

单商户商城系统功能拆解38—分销应用—分销订单

c 下面以likeshop单商户高级版 商城系统为例进行功能拆解,likeshop单商户高级版商城系统可以实现快速部署,文档齐全,代码全开源,无加密,极易二次开发,助力企业以极低的成本上线电商业务。并且likeshop以其…

Java项目模块占用CPU过高问题分析

背景:近期一个模块(暂且称为A)新上了一个需求,改动了些代码,在测试环境部署之后,该模块系统CPU使用率动不动就飙升到90%,甚至200%,严重影像其他业务执行。排查过程 1.使用top查看当…

【LeetCode】813. 最大平均值和的分组

题目描述 给定数组 nums 和一个整数 k 。我们将给定的数组 nums 分成 最多 k 个相邻的非空子数组 。 分数 由每个子数组内的平均值的总和构成。 注意我们必须使用 nums 数组中的每一个数进行分组,并且分数不一定需要是整数。 返回我们所能得到的最大 分数 是多少。答…

eclipse中创建的Maven Module和Maven Project及其间区别

eclipse中创建Maven Module和Maven Project及其间的区别Maven Module和Maven ProjectProject和Module的关系及用法Maven Module工程必须有父工程Maven Module和Maven Project Maven Project可以理解为父工程,是最上级的项目,一般没有其他parent项目。是一…

Word控件Spire.Doc 【图像形状】教程(6): 如何在 C#、VB.NET 的 Word 文档中插入形状和形状组

Spire.Doc for .NET是一款专门对 Word 文档进行操作的 .NET 类库。在于帮助开发人员无需安装 Microsoft Word情况下,轻松快捷高效地创建、编辑、转换和打印 Microsoft Word 文档。拥有近10年专业开发经验Spire系列办公文档开发工具,专注于创建、编辑、转…

天河超算,安装Hypre

1)下载,解压 略 得到目录:hypre-master 源文件在src目录下面 src包含如下目录: 2)cmake编译 版本比较新 HYPRE_RELEASE_NAME hypre HYPRE_RELEASE_VERSION 2.26.0 HYPRE_RELEASE_DATE 2022/10/14 HYPRE_RELEASE_TIM…

CT正投影算法归纳

一、CT重建基本原理 CT 系统成像基本模型可以描述成:   f为待重建图像,P为投影数据,W为系统矩阵,其中,投影矩阵反映探测器上的投影与重建物体的关系,其模型刻画对于重建速度和精度有着重要影响。 二、…

Java:多线程基础(一)-创建线程的两种方式

目录 线程与进程 Thread类 创建线程的两种方式 方式1:继承Thread类 方式2:实现Runnable接口 * 方式2延伸:实现Callable接口 Callable接口 Futuretask类 返回线程计算结果:get() Callable:创建子线程…

Redis实战之共享session + jwt 实现登录拦截、刷新token

共享session问题 每个tomcat中都有一份属于自己的session,假设用户第一次访问第一台tomcat,并且把自己的信息存放到第一台服务器的session中,但是第二次这个用户访问到了第二台tomcat,那么在第二台服务器上,肯定没有第一台服务器…

百度边止血边扩张

在经过一系列的“内部调整”之后,百度交出了一份超预期的财报。北京时间11月22日,百度发布了截至2022年9月30日的第三季度财务报告。第三季度,百度实现营收325.4亿元,同比增长2%;归属百度的净利润(non-GAAP…

在线杂志小程序开发,开启在线阅读时代

互联网技术的快速发展,让人们越来越依赖从网络上查看各种新闻资讯。传统的纸质杂志已经很难顺应时代的发展脚步,但是人们对于杂志的需求并没有减少。因此为了更好的满足众多读者对于杂志的需求,开发在线杂志小程序是十分必要的。在线杂志阅读…

时光倒流-第12届蓝桥杯Scratch选拔赛真题精选

[导读]:超平老师计划推出Scratch蓝桥杯真题解析100讲,这是超平老师解读Scratch蓝桥真题系列的第88讲。 蓝桥杯选拔赛每一届都要举行4~5次,和省赛、国赛相比,题目要简单不少,再加上篇幅有限,因此我精挑细选…

医院预约小程序源码,挂号陪护就医功能,提供全方位服务

随着人口老龄化形式加剧,年轻人工作压力大,没有闲余时间陪伴父母老人,因此针对解决独自去医院排队以及现代化设备需要等要求,而衍生出来的一个新型行业-挂号陪护。医院预约小程序源码开发的出现无非就是解决了这一难题&#xff0c…

教培行业迎来重大变局,三大方向或成新机遇

“双减”政策落地,教培行业迎来重大变局。校内教育深化改革正在路上,而学科类机构或将踏上转型之路,结合政策和市场来看,素质教育类、职业教育类、教育数字化3大方向或成新机遇。 “双减”的总体思路是什么呢? 教育部有…

[附源码]计算机毕业设计SpringbootON-FIT

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

QGIS下载在线地图(Google 卫星、esri 卫星)

前言 国内外有很多在线地图下载软件,但功能单一,基本上只能下载数据,无法做GIS分析,且多为收费,即便是免费,也多少有所限制。 在QGIS中,可以完全免费且迅速下载在线地图,首先请看阅…

Kafka集群环境的部署

Kafka集群环境的搭建一、Kafka集群二、搭建两台服务器2.1、 zookeeper部署2.2、 启动1号机器的broker2.3、 启动2号机器的broker2.4、查看kafka集群2.5、测试集群总结后言一、Kafka集群 二、搭建两台服务器 笔者的两台服务器IP: 服务器IP1号192.168.11.592号192.1…