程序员过关斩将--互联网人必备知识cookie和session认证

640

菜菜,上次你说的cookie和session的文章,我觉得不太具体

640

640?wx_fmt=jpeg

那你想怎么样具体呢?

640

640?wx_fmt=jpeg

我自己从网上查了一下,很多关于cookie和session认证的,能不能给我讲讲

640

640?wx_fmt=jpeg

用户认证呀,可以呀

640

640?wx_fmt=jpeg

这样我下次再去面试,有可能会遇到这样的问题

640

640?wx_fmt=jpeg

原来你是想为面试做准备呀,看来公司收不住你的心了

640

640?wx_fmt=jpeg

640?wx_fmt=png

用户认证

640

在互联网发展初期,Web基本上只是内容的浏览而已,服务器不需要记住每个浏览请求的状态,换句话说,服务器不需要有任何的状态信息,每次客户端的请求都是新的请求,这也是http无状态一个很明显的表现。随着互联网大潮的到来,尤其是像在线购物等这种和用户关系密切的系统的大量兴起,系统需要辨识出用户,以便进行各种业务操作,这种需求给Http无状态这种特性一个强烈的冲击,所以最终的解决方案就是客户端请求的时候携带着一种标识,这种标识每个用户不同,这样服务端就可以根据这个标识区分出不同的客户端用户了,这也就诞生了用户认证这个概念。

640

由于http协议是无状态的,所以基于http协议进行的认证,都需要依赖客户端上传的某种标识

640

所谓身份认证,就是判断一个用户是否为合法用户的处理过程。

640

以上是百科针对于用户认证的泛型定义,和认证相关的授权这里要顺便提一下,认证和授权是两个不同的概念,更是两个不同的阶段,绝大多数带有认证和授权的系统,在用户操作流程上都是先进行认证,之后根据认证的结果再进行授权操作,有的初学者容易混淆二者的概念。举一个很简答的栗子:一个OA系统,在用户登录成功之后,一般左侧都会根据当前用户的不同角色或者权限出现不同操作的菜单树,其中用户登录这个过程就是认证的过程,而左侧的菜单树就是对当前用户的授权的一个具体表现形式(当然有的系统可能不这样做,但不代表没有授权的流程)。

640?wx_fmt=png

640

认证是用来证明一个用户身份的操作流程,授权是用来给当前用户赋予权限的操作流程

session认证

640

通过上一篇文章,相信大家已经明白了session和cookie的关系,如果你还没看过,我推荐还是看一下吧。

640

Session:在计算机中,尤其是在网络应用中,称为“会话控制”。Session对象存储特定用户会话所需的属性及配置信息。这样,当用户在应用程序的Web页之间跳转时,存储在Session对象中的变量将不会丢失,而是在整个用户会话中一直存在下去。当用户请求来自应用程序的 Web页时,如果该用户还没有会话,则Web服务器将自动创建一个Session对象。当会话过期或被放弃后,服务器将终止该会话。

640

基于session的认证方式,最主要的一个特点就是:服务端存储着用户信息,客户端是通过携带一个sessionid的cookie来做session的标识。很多初期项目都喜欢采用session的认证方式,这种方式对于快速开发上线项目极为有利。每个客户端只需要保存一个cookie,但是服务端却需要保存成千上万的用户session信息,这无疑对服务端造成了很大的压力,尤其是当做了负载均衡之后,session的命中问题更为可怕。举个栗子:用户A登录系统成功,服务器A下发sessionid,session信息存储在服务器A上,如果当下次请求到服务器B上的时候,由于服务器B上没有session信息,所以就造成了未命中的现象,这也是session认证解决方案实施过程面临的一个问题。有问题就有解决方案,其中一个便是session复制,服务端的每个服务器都存储每个session的一个副本,这样请求无论到达哪个服务器,都可以成功取到session信息,但是这样无疑增大了服务的存储压力,而且session在服务器之间的复制延迟,session信息的更新同步、过期同步等操作都令人头疼。所以这种方案在一定程度上其实并不推荐。

目前业界关于session存储的方案一般都倾向于集中式存储,像利用第三方的redis,Memcached把session信息都存储在同一个地方,所有的服务器都访问这个地方的数据。这样就避免了session复制,同步等问题。但是引入了第三方,就意味着增加了一个第三方挂掉的可能性,所以现在都基本采用第三方集群的方案来尽量减小这种可能性,把高可用性做到极致。另外说一点,由于大多数session机制是基于cookie的,在一定程度上对于浏览器比较友好,但是对于很多移动端应用其实并不是太友好。

640?wx_fmt=png

640?wx_fmt=png

640

由于session的认证信息保存在服务端,数据量到达一定程度对服务器有一定的压力,即使是采用第三方的存储(比如redis)可以缓解这种问题,但是服务器和第三方存储的IO操作所花费的时间有的时候也是很大的。在这种情况下,有的系统放弃了session的认证方式,而直接采用的最直接的cookie认证方式。

和session认证不同,用户的认证信息完全存储在cookie中,换句话说用户的认证信息存储在客户端(这也是为什么不推荐在cookie认证中存放敏感信息)。cookie认证这种方式的优势就在于服务端没有了session存储的压力,每次识别用户都只需要解析cookie的内容即可(解析cookie其实也需要花费时间),相比较第三方存储session的方式,减少了一次网络IO操作,在一定程度上提高了请求的响应速度,而且由于服务端处于无状态的形式,所以可以很方便的横向扩展。

基于cookie的认证方式也有很多缺点:

1. cookie是存储在客户端的,所以在一定程度上增加了可以伪造的几率,安全性上稍微弱一点。

2. 由于cookie在浏览中有跨域的阻拦,所以在有跨域需求的时候,需要服务器做相应的配置。

3. cookie是有长度限制的,所以不宜存储过长的信息。

4. 用户的客户端可能会禁用cookie,这个时候可以依靠url传值来解决这个问题。

5. 服务端想要操作cookie认证信息的失效,比较困难,不像session认证那样方便。

其实我司现在老的系统都是利用的cookie验证方式,只不过cookie信息的加密算法很好,而且再加上全站https的策略,在一定程度上安全性还是可以的(如果让我重构一次认证系统,我不会选择cookie认证)。

写在最后

640

无论是基于session的还是基于cookie的认证方式,都需要客户端上传标识,都需要服务端下发这个标识,并且对这个标识进行加密。虽然加密,但是不法之人一旦拿到这个标识还是可以进行一系列非法操作,所以这个标识里边最好能加上来源IP和过期时间这些属性,再配置上https,可以更加有效的保护整个认证流程和数据。也许还有更好的认证方式,敬请期待!!

640?wx_fmt=gif

●程序员过关斩将--cookie和session的关系其实很简单

●程序员修神之路--用NOSql给高并发系统加速

●程序员修神之路--高并发系统设计负载均衡架构

●程序员修神之路--做好分库分表其实很难之一(继续送书)

●程序员修神之路--做好分库分表其实很难之二(送书继续)

●程序员过关斩将--你为什么还在用存储过程?

●程序员过关斩将--小小的分页引发的加班血案

●程序员修神之路--问世间异步为何物?

●程序员修神之路--提高网站的吞吐量?

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

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

相关文章

2019-03-15-算法-进化(两数之和)

题目描述 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。 你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。 示例: 给定 nums [2, 7, 1…

51nod 1847 奇怪的数学题(数论/min25筛/杜教筛/斯特林数)

51nod 1847 奇怪的数学题 求解∑i1n∑j1nsgcd(i,j),sgcd\sum_{i1}^n\sum_{j1}^nsgcd(i,j),sgcd∑i1n​∑j1n​sgcd(i,j),sgcd表示次大公约数,n≤1010n\le{10^{10}}n≤1010 那么首先有sgcd(i,j)gcd(i,j)/mn(gcd(i,j))sgcd(i,j)gcd(i,j)/mn(gcd(i,j))sgcd(i,j)gcd(i,j)/mn(gcd(…

.NET Core ASP.NET Core Basic 1-2 控制反转与依赖注入

本节内容为控制反转与依赖注入简介控制反转IOC这个内容事实上在我们的C#高级篇就已经有所讲解,控制反转是一种设计模式,你可以这样理解控制反转,假设有一个人他有一部A品牌手机,他用手机进行听歌、打游戏,那么你可以创…

2019-03-15-算法-进化(有效的数独)

题目描述 判断一个 9x9 的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可。数字 1-9 在每一行只能出现一次。 数字 1-9 在每一列只能出现一次。 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。上图是一个部分填充的有效的数独。 数独…

STL归并排序

STL归并排序 https://blog.csdn.net/weixin_44176696/article/details/104431124 分为原地归并和异地归并,而且可以自定义比较函数,非常方便。

清明梦超能力者黄YY、异或树(线段树合并)

清明梦超能力者黄YY 这题有点像【雨天的尾巴】【永无乡】的结合版本,树上差分,线段树合并,权值线段树查找第kkk大。 对于操作iii,我们可以对u−>vu->vu−>v路径上的点,iii的权值加上111,然后线段…

net core WebApi——尝试企业微信来开发企业内部应用

前言这几天忙活着别的东西,耽误了很长时间,从文件操作完了之后就在考虑着下一步鼓捣点儿啥,因为最开始的业务开发就是企业微信相关的,这刚好来做个内部应用的小例子玩玩。企业微信前身是企业号,当时微信主推的还是公众…

2019-03-18-算法-进化(字符串中的第一个唯一字符)

题目描述 给定一个字符串,找到它的第一个不重复的字符,并返回它的索引。如果不存在,则返回 -1。 案例: s "leetcode" 返回 0.s "loveleetcode", 返回 2.注意事项:您可以假定该字符串只包含小写字母。 思…

P2619 [国家集训队]Tree I(WQS二分/带权二分/最小生成树)

P2619 [国家集训队]Tree I 给定一个n个点,m条边的无向图,每条边有一个颜色黑色或者白色,求解恰好有k条白色边的最小生成树。 那么看到恰好选择k个的最优性问题,我们可以利用WQS二分解决,实际上就是利用了对于每个选择…

E. Party Company(树上问题)

E. Party Company 容易发现这是一颗树形结构,根节点为111,并且有点权从根节点开始递减。 题目大意就是给定一个点u,l,ru, l, ru,l,r,对于于uuu在同一个连通块里,并且点权是在[l,r][l, r][l,r]之间的点答案贡献加一。 如果理解到…

微软发布了开发社区采用.NET Standard的最新信息

最近,微软发布了开发社区当前采用.NET Standard的最新信息。.NET Standard是API的正式规范,现有.NET实现在不同平台的是通用的(从而允许跨平台开发)。当前规范(版本2.0)在两年前发布,在.NET Cor…

2019-03-18-算法-进化(实现strStr())

题目描述 实现 strStr() 函数。 给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。 示例 1: 输入: haystack "hello", needle "ll" 输…

CF429E Points and Segments(欧拉回路)

CF429E Points and Segments 给定n 条线段[li,ri][l_i,r_i][li​,ri​] ,然后给这些线段红蓝染色,求最后直线上上任意一个点被蓝色及红色线段覆盖次数之差的绝对值不大于1 首先见到绝对值不大于1我们就容易想到欧拉回路,因为欧拉回路可以用来构造恰好相…

卓语言对泛型类的使用

上次发了中文编程语言卓语言《小卓.NET中文编程特点介绍》。这篇文章来看下卓语言对泛型类的使用。泛型是现代编程语言很重要的功能。C#语言可以完全定义和使用泛型类型。卓语言是面向广大非专业人员的,为了减低编程难度,没有实现定义泛型类型&#xff0…

快速傅里叶变换(完整推导过程 + 模板)

快速傅里叶变换 多项式表示 系数表示法: 一个nnn次多项式可以用n1n 1n1个系数表示出来:f(x)a0a1xa2x2⋯an−1xn−1anxnf(x) a_0 a_1 x a_2 x ^ 2 \dots a_{n - 1} x ^{n- 1} a_n x ^nf(x)a0​a1​xa2​x2⋯an−1​xn−1an​xn。 点值表示法&a…

2019-03-19-算法-进化(报数)

题目描述 报数序列是一个整数序列,按照其中的整数的顺序进行报数,得到下一个数。其前五项如下: 1. 1 2. 11 3. 21 4. 1211 5. 1112211 被读作 “one 1” (“一个一”) , 即 11。 11 被读作 “two 1s” (“两个一”&…

AT2675 [AGC018F] Two Trees(欧拉回路)

AT2675 [AGC018F] Two Trees 首先我们看到1或-1,那么就是限制差距在1以内,然后我们可以想到构造一些东西来满足这种东西,然后我们经常利用的就是欧拉回路。 首先这是两个树,然后我们可以根据儿子个数来判断当前点的奇偶性&#x…

.netcore 分布式事务CAP2.6之控制台使用

上一编.netcore 分布式事务CAP2.6 快速入门 讲了cap2.6的快速入门,这次我们来讲讲在控制台中如何使用cap2.6。因为cap2.6的内存模式目前已经可以使用了,相关组件已经更新,所以这次我们以简单的内存模式为例。1:创建项目创建一个名…

2019-03-18-算法-进化(有效的字母异位词)

给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的一个字母异位词。 示例 1: 输入: s "anagram", t "nagaram" 输出: true示例 2: 输入: s "rat", t "car" 输出: false说明: 你可以假设字符串只包含小写字母…

P6378 [PA2010] Riddle(2-sat/前后缀优化建图)

P6378 [PA2010] Riddle n个点m条边的无向图,分为k个部分,从每个部分选择恰好一个关键点,使得每条边至少有一个端点是关键点。 首先有这么多的限制,实际上就是一个选或者不选的问题,每条边的限制相当于一个不选就必须…