首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >「小程序JAVA实战」java-sesion的状态会话与无状态会话(38)

「小程序JAVA实战」java-sesion的状态会话与无状态会话(38)

作者头像
IT架构圈
发布于 2019-07-08 02:09:33
发布于 2019-07-08 02:09:33
5830
举报
文章被收录于专栏:IT架构圈IT架构圈

我相信大家在参与web开发的时候,肯定会遇到session,其实在平常的开发过程中,用到的session都是有状态的session。

有状态的session

正常的web开发,每次来一个用户就会产生一个session,在客户端会受到sessionId的概念,每个用户有个独立的session会话,如果100个用户进来就会产生100个session的会话。如果这个会话消失了,用户的没有在访问我们的网站,这就是我们日常使用最多的会话,成为有状态会话。

无状态的session

上边说了有状态,相对而言肯定是有无状态session的存在。除去混合开发的模式,直接原生的安卓,ios,小程序开发他们访问直接地址的时候就存在无状态session。他们这种会话是无法维系用户和系统之间的关系的。他们访问一次获取后就断开了连接。每次都是一个新的会话。这种我们必须在后端做一系列的控制,来维系用户和系统之间的关系。tomcat等容器无法做到的话。我们就要使用内存redis来完成。

Redis-session

用户在访问的时候会产生一个user-redis-session,把用户的信息json的形式保存在redis里面,我们也可以给redis增加失效时间,不管是单支和集群redis,对用户来说都是无感知的。

  • 好处

用户信息存储到redis缓存中,形成无状态会话。方便管理 便于扩展,当单体应用该扩展成集群。 便于权限验证。

PS:下次使用redis建立无状态的session。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-12-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编程坑太多 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
一文了解web无状态会话token技术JWT
目前web开发前后端已经算非常的普及了。前后端分离要求我们对用户会话状态要进行一个无状态处理。我们都知道通常管理用户会话是session。用户每次从服务器认证成功后,服务器会发送一个sessionid给用户,session是保存在服务端 的,服务器通过session辨别用户,然后做权限认证等。那如何才知道用户的session是哪个?这时候cookie就出场了,浏览器第一次与服务器建立连接的时候,服务器会生成一个sessionid返回浏览器,浏览器把这个sessionid存储到cookie当中,以后每次发起请求都会在请求头cookie中带上这个sessionid信息,所以服务器就是根据这个sessionid作为索引获取到具体session。
码农小胖哥
2019/12/05
2.1K0
01-分布式会话[会话的定义, 无状态会话, 有状态会话...]
会话Session代表的是客户端与服务器的一次交互过程,这个过程可以是连续也可以是时断时续的。曾经的Servlet时代(jsp),一旦用户与服务端交互,服务器用户创建一个session,同时前端会有一个jsessionid,每次交互都会携带。如此一来,服务器只要在接到用户请求时候,就可以拿到jsessionid,并根据这个ID在对应的会话session,当拿到session会话后,那么我们就可以操作会话了。会话存活期间,我们就能认为用户一直处于正在使用着网站的状态,一旦session超期就可以认为用户已经离开网站,停止交互了。用户的身份信息,我们也是通过session来判断的,在session中可以保存不同用户的信息。session的使用之前在单体部分演示过,代码如下:
彼岸舞
2022/10/04
2090
01-分布式会话[会话的定义, 无状态会话, 有状态会话...]
3种web会话管理的方式
http是无状态的,一次请求结束,连接断开,下次服务器再收到请求,它就不知道这个请求是哪个用户发过来的。当然它知道是哪个客户端地址发过来的,但是对于我们的应用来说,我们是靠用户来管理,而不是靠客户端。所以对我们的应用而言,它是需要有状态管理的,以便服务端能够准确的知道http请求是哪个用户发起的,从而判断他是否有权限继续这个请求。这个过程就是常说的会话管理。它也可以简单理解为一个用户从登录到退出应用的一段期间。本文总结了3种常见的实现web应用会话管理的方式:
wangxl
2018/07/27
1.5K0
为什么强调 RESTful 的无状态性?-优雅草卓伊凡
RESTful 架构的核心原则之一是 无状态性(Statelessness),它要求 每次客户端请求必须包含服务器处理该请求所需的所有信息,服务器不会存储客户端的状态(如会话、上下文)。这种设计带来以下关键优势:
卓伊凡
2025/05/08
950
HTTP 协议无状态中的 "状态" 到底指的是什么?
最近在好好了解http,发现对介绍http的第一句话【http协议是无状态的,无连接的】就无法理解了:无状态的【状态】到底指的是什么?!
程序员白楠楠
2020/12/04
1.6K0
3种web会话管理的方式
http 是无状态的,一次请求结束,连接断开,下次服务器再收到请求,它就不知道这个请求是哪个用户发过来的。当然它知道是哪个客户端地址发过来的,但是对于我们的应用来说,我们是靠用户来管理,而不是靠客户端。所以对我们的应用而言,它是需要有状态管理的,以便服务端能够准确的知道 http 请求是哪个用户发起的,从而判断他是否有权限继续这个请求。这个过程就是常说的会话管理。它也可以简单理解为一个用户从登录到退出应用的一段期间。本文总结了 3 种常见的实现 web 应用会话管理的方式:
chengcheng222e
2021/11/04
7780
渗透测试XSS漏洞原理与验证(1)——会话管理
HTTP是一种无状态协议,一次请求结束,客户端与服务端的连接就会断开,服务器再次收到请求时,无法识别此次请求是哪个用户发过来的,需要重新建立连接。为了判断发送请求的用户,需要一种记录用户的方式,也就是Web应用会话管理。
zhouzhou的奇妙编程
2024/10/08
2060
谈一谈分布式会话
会话Session代表的是客户端与服务器的一次交互过程,这个过程可以是连续也可以是时断时续的。曾经的Servlet时代(jsp)),一旦用户与服务端交互,服务器tomcat就会为用户创建一个session,同时前端会有一个jsessionid,每次交互都会携带。如此一来,服务器只要在接到用户请求时候,就可以拿到jsessionid,并根据这个ID在内存中找到对应的会话session,当拿到session会话后,那么我们就可以操作会话了。会话存活期间,我们就能认为用户一直处于正在使用着网站的状态,一旦session超期过时,那么就可以认为用户已经离开网站,停止交互了。用户的身份信息,我们也是通过session来判断的,在session中可以保存不同用户的信息。session的使用之前在单体部分演示过,代码如下∶
用户7353950
2022/06/23
2040
谈一谈分布式会话
Session会话与Cookie简单说明
会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话。常用的会话跟踪技术是Cookie与Session。Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端记录信息确定用户身份。经常有人会疑惑:Session会话与Cookies的区别是什么?用户登录的原理是什么?网站是如何认证的?它怎么知道是哪个用户从哪儿登录进来的?下面将对这些问题进行一一解答。
洗尽了浮华
2022/03/29
2K0
Session会话与Cookie简单说明
Spring Session - Cookie VS Session VS Token 以及 Session不一致问题的N种解决方案
我们在学习Spring Session 之前, 先聊聊 几种主流的会话方式以及发展历史
小小工匠
2021/08/17
1.1K0
会话跟踪技术之Session
Session介绍 什么是Session? 背景:HTTP协议是无状态协议,无状态是指每次request请求之前是相互独立的,当前请求并不会记录它的上一次请求信息 问题:既然无状态,那么完成一整套业务逻辑,需要发送多次请求,那么怎么标识这些请求都是同一个浏览器操作呢? cookie和session都是为了弥补http协议的无状态特性,对server端来说无法知道两次http请求是否来自同一个用户,利用cookie和session就可以让server端知道多次http请求是否来自同一用户 生成和使用流程(和C
高大北
2022/06/14
2370
聊聊分布式会话及实现方案
http协议本身是无状态的,客户端只需要向服务器请求下载内容,客户端和服务器都不记录彼此的历史信息,每一次请求都是独立的。
鲁大猿
2024/01/04
2640
聊聊分布式会话及实现方案
面试官:请说3种常用的 Web 会话管理方式
http 是无状态的,即我们的一次请求结束后,下一次请求,服务端他并不知道是哪个用户发来的。
小锟哥哥
2022/12/05
4960
面试官:请说3种常用的 Web 会话管理方式
session机制详解以及session的相关应用
session是web开发里一个重要的概念,在大多数web应用里session都是被当做现成的东西,拿来就直接用,但是一些复杂的web应用里能拿来用的session已经满足不了实际的需求,当碰到这样的情况时候我们需要更加深入的理解session的机制,本文将梳理下session的相关知识,为设计可替代web容器自带的session机制打个基础。 1.1 session的概念 在计算机专业术语里:session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册入系统到注销系统之间所经过的时间以及如果需
Ryan-Miao
2018/03/13
1.6K0
session机制详解以及session的相关应用
快醒醒,Cookie + Session 的时代已经过去了
这篇文章主要在做 Echo 社区项目的时候写的,在保持用户登录态的这个需求下,为啥要用 ThreadLocal 存储用户信息,而不是采用常见的 Cookie + Session。
飞天小牛肉
2022/02/23
4310
快醒醒,Cookie + Session 的时代已经过去了
理解分布式会话
会话 Session 代表的是客户端与服务器的一次交互过程,这个过程可以是连续也可以是时断时续的。早期的 Servlet时代(jsp),一旦用户与服务端交互,服务器 tomcat 就会为用户创建一个 session,同时前端会有一个 jsessionid,每次交互都会携带。如此一来,服务器只要在接到用户请求时候,就可以拿到 jsessionid,并根据这个ID在内存中找到对应的会话 session,当拿到 session 会话后,那么我们就可以操作会话了。会话存活期间,我们就能认为用户一直处于正在使用着网站的状态,一旦 session 超期过时,那么就可以认为用户已经离开网站,停止交互了。用户的身份信息,我们也是通过session 来判断的,在 session 中可以保存不同用户的信息。
乐心湖
2021/01/18
7220
理解分布式会话
30s 看懂最基础的认证方式: Session-Cookie 认证
图解最基础的认证方式:Session-Cookie,依次解释其基本步骤、伪代码、缺点以及相应的解决方案
飞天小牛肉
2023/01/11
9320
网络编程之浅谈http无连接、无状态
一、http协议 HTTP(超文本传输协议)是一个客户端和服务器端请求和应答的标准(TCP)。客户端是终端用户,服务器端是网站。通过使用Web浏览器、网络爬虫或者其它的工具,客户端发起一个到服务器上指定端口(默认端口为80)的HTTP请求。http是一个属于应用层的面向对象的协议,HTTP 协议一共有五大特点:1、支持客户/服务器模式;2、简单快速;3、灵活;4、无连接;5、无状态。 二、如何理解HTTP协议的“无连接,无状态”特点 1、无连接   无连接的含义是限制每次连接只处理一个请求。服务器处理完
lyb-geek
2018/03/27
1.6K0
服务化构建-服务的无状态化能带来什么?
HTTP 中的无状态理解为单次 HTTP 请求响应 可以独立完成,每次请求不需要与上次请求有太多的关联和牵扯。
needrunning
2020/06/15
1.6K0
php负载中使用redis实现session会话保持
首先要明确session和cookie的区别。浏览器端存的是cookie每次浏览器发请求到服务端是http 报文头是会自动加上你的cookie信息的。服务端拿着用户的cookie作为key去存储里找对应的value(session). 同一域名下的网站的cookie都是一样的。所以无论几台服务器,无论请求分配到哪一台服务器上同一用户的cookie是不变的。也就是说cookie对应的session也是唯一的。 所以,这里只要保证多台业务服务器访问同一个redis服务器(或集群)就行了。
张琳兮
2019/03/14
1.5K0
相关推荐
一文了解web无状态会话token技术JWT
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档