session问题总既然(深入理解)&Token问题理解&sso单点登陆理解实现
一.Session使http协议成为有状态协议(浏览器cookie本地这个session,服务器端也有这个session)
1.ajax前端登陆无法保存session,造成无法维持登陆状态(http本身就是无状态协议,登陆就是要变成有状态协议)?怎么解决?
:后台一直显示没有登陆,虽然前端已经登陆了。(默认用session保持的登陆状态)
1).查看前端是否传sessionID过来了,session是保存在客户端的cookie里的,同时又是保存在服务器端的,两端都有session才能保持登陆状态嘛。
2).果然,发现虽然登陆成功了,但是后面的接口请求,http header里并没有传过来session。
3).就需要登陆操作后,js调用浏览器存储下来刚刚得到的sessionID。
但前端是无法存储数据的,只能通过调用浏览器的cookie来进行存储这个session。下次再调用时候传过来这个sessionID。
二.Token使Http协议成为有状态协议
1.理解流程和session一样,要生成一个数据,浏览器前端和后端都有的中介介质,才能让前后端成为有状态协议。
怎样维持状态?当然是要有共同的东西啊,才能维护有状态协议。
具体HTTP成为有状态协议步骤:
1).登陆操作行为时:传过来用户名和密码,判断是否正确。如果正确,则产生session(服务器容器会自动生成session,这时候你只需要在这个session里存储数据即可)或者生成一个Token。
注:产生session/Token这个步骤永远在登陆接口里,用户名或者密码验证成功后。
2)将登陆成功后产生的这个sessionID或者Token返回给前端,前端进行保存,后续其他接口要传入这个数据。
三。Token和Session区别
1)Token和Session的区别:
Token是完全由程序员自己决定生成策略的。并要程序员自己要想好这个Token存储在哪里,Token不像Session由容器自己来存储和维护(Session就是一个cocurrenthashmap)。所以程序员自己要决定好在哪里存储Token,一般都要利用专门的Redis缓存服务器来存储这个Token。
Session保存在本地服务器容器中,程序员不用管怎么生成,只需要登录成功后向本例的Session里面塞入数据即可。Session你需要担心的就是因为是本地存储,存在内存被撑爆的风险,内存不够用啊怕。所以用Session,只适用于用户量比较小的场景,比如后台管理系统等。
2)Session或者Token都是有保质期的,避免长期生成及避免内存被撑爆。自己生成的Token也要有保质期,Redis可以设置保质期。
Tomcat默认生成的Session生命周期是30分钟,
四.SSO单点登陆说白了就是在单独一个地方负责去存储和验证这个Token。
SSO单点登陆说白了就是在单独一个地方负责去存储和验证这个Token。
SSO单点登陆说白了就是在单独一个地方负责去存储和验证这个Token。
每个业务系统都去这个单点登陆服务器去请求生成Token,和验证某个Token的有效性。
每个业务系统都去这个单点登陆服务器去请求生成Token,和验证某个Token的有效性。
每个业务系统都去这个单点登陆服务器去请求生成Token,和验证某个Token的有效性。
三。JWT变相实现让HTTP成为有状态协议
原理:每次的请求,jwt算法都会返回下次访问需携带的Token,这样两端都不需要保存Token或者Session。
所以JWT要做的就是1.检验本此传入请求的Token有效性及2.产生下次访问旭携带的Token
session问题总既然(深入理解)&Token问题理解&sso单点登陆理解实现的更多相关文章
- IM开发基础知识补课:正确理解前置HTTP SSO单点登陆接口的原理
1.前言 一个安全的信息系统,合法身份检查是必须环节.尤其IM这种以“人”为中心的社交体系,身份认证更是必不可少. 一些PC时代小型IM系统中,身份认证可能直接做到长连接中(也就是整个IM系统都是以长 ...
- sso单点登录系统(解决session共享)
场景:假设一个用户将自己的登录信息提交到后台,如果session保存的信息分布在多台机器上,并且不共享,那么可能导致用户的登录信息出现短暂的丢失,为什么这样讲,因为用户访问服务器中间还要经过负载均衡服 ...
- 快速理解Token,Cookie,Session
在Web应用中,HTTP请求是无状态的.即:用户第一次发起请求,与服务器建立连接并登录成功后,为了避免每次打开一个页面都需要登录一下,就出现了cookie,Session. Cookie Cookie ...
- [深入理解Android卷一全文-第八章]深入理解Surface系统
由于<深入理解Android 卷一>和<深入理解Android卷二>不再出版.而知识的传播不应该由于纸质媒介的问题而中断,所以我将在CSDN博客中全文转发这两本书的全部内容. ...
- .NET Core2.0+MVC 用session,cookie实现的sso单点登录
博主刚接触.NET Core2.0,想做一个单点登录的demo,所以参考了一些资料,这里给上链接: 1.http://www.cnblogs.com/baibaomen/p/sso-sequence- ...
- 深入理解跨域SSO(单点登录)原理与技术
一:SSO体系结构 SSO SSO英文全称Single Sign On,单点登录.SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统.它包括可以将这次主要的登录映射到其他 ...
- [深入理解Android卷一全文-第十章]深入理解MediaScanner
由于<深入理解Android 卷一>和<深入理解Android卷二>不再出版,而知识的传播不应该由于纸质媒介的问题而中断.所以我将在CSDN博客中全文转发这两本书的全部内容. ...
- 深入理解跨域SSO单点登录原理与技术
[本文版权归微信公众号"代码艺术"(ID:onblog)所有,若是转载请务必保留本段原创声明,违者必究.若是文章有不足之处,欢迎关注微信公众号私信与我进行交流!] 一:SSO体系结 ...
- Spring Cloud云架构 - SSO单点登录之OAuth2.0 根据token获取用户信息(4)
上一篇我根据框架中OAuth2.0的使用总结,画了SSO单点登录之OAuth2.0 登出流程,今天我们看一下根据用户token获取yoghurt信息的流程: /** * 根据token获取用户信息 * ...
随机推荐
- android 2.2 preview3 编译bug
平台 as2.2 preview3; 1. 解决方法: 在project.buildgradle 里面设置 // Top-level build file where you can add co ...
- .Net Mvc EasyUI DataGrid 分页
由于项目的需要,最近一直在学习 .net MVC 和EasyUI.上周写了一个<.Net Mvc 返回Json,动态生成EasyUI Tree>,今天再写一个EasyUI中另一个重要的组件 ...
- qt5.8 链接mysql错误:driver not load
转载请注明出处:http://www.cnblogs.com/dachen408/p/7155858.html 问题:qt5.8 链接mysql错误:driver not load. 解决方案:1.安 ...
- MongoDB入门解析
刚开始学习mongodb,对笔记做了一个整理.是基于nodejs来学习的. 1.mongodb介绍 mongodb 是C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添 ...
- java web 学习笔记 - 表达式语言
1.表达式语言简介 主要为了简化mvc中 jsp的代码量,方便进行属性的输出.还可以避免进行属性为空等的判断,表达式默认将null设置为"". 表达式语言的一个最大的好处就是,只需 ...
- Code::Blocks使用与调试一条龙
CodeBlocks创建C语言工程版本13.12 选择"create a new project" 选择第四个,点击"go" 4 选择"C&quo ...
- 数据层优化-jdbc连接池简述、druid简介
终于回到既定轨道上了,这一篇讲讲数据库连接池的相关知识,线程池以后有机会再结合项目单独写篇文章(自己给自己挖坑,不知道什么时候能填上),从这一篇文章开始到本阶段结束的文章都会围绕数据库和dao层的优化 ...
- Mybatis输入输出映射_动态sql_关联关系(一对一、一对多、多对多)
Mybatis输入输出映射_动态sql_关联关系(一对一.一对多.多对多)输入输出映射parameterType完成输入映射parameterType可以传入的参数有,基本数据类型(根据id查询用户的 ...
- Spring Data Redis整体介绍 (一)
为什么使用Spring Data Redis 首先Spring Data Redis 是Spring 框架提供的用于操作Redis的客户端. Spring框架是一个全栈Java程序框架,通过DI.AO ...
- ios中摄像头/相册获取图片压缩图片上传服务器方法总结
本文章介绍了关于ios中摄像头/相册获取图片,压缩图片,上传服务器方法总结,有需要了解的同学可以参考一下下. 这几天在搞iphone上面一个应用的开发,里面有需要摄像头/相册编程和图片上传的问 ...