OAuth2协议
admin
2024-02-14 03:11:28
0

前言

        OAuth是一个关于授权的开放网络标准,主要是用来让用户授权给第三方应用从而或者用户在服务器的一些数据

        通俗点讲,用户在A网站有几张图片,但是获取的时候需要进行登录,而用户在B网站的时候也需要获取这几张图片,然而B服务器是没有这些数据的,他需要从A网站中获取用户的数据,这样一来,就需要用户在B网站进行授权,让B网站可以提取用户在A网站的数据,最典型的就是使用微信登录第三方网站,估计这个随处可见

核心概念

资源拥有者:也就是用户,简单可以理解为微信用户

客户端:就是要获取用户的第三方应用,例如上面的B网站

授权服务器:用来提供接口给B客户端获取资源拥有者的访问权限的

资源服务器:用户存储的资源所在的服务器,通常来说和授权服务器是在一起的

以上为Oauth2协议中的核心角色,接下来还有一些核心参数,如下

client_id: 客户端id,第三方软件需要在A网站进行注册,然后A 网站会返回的一个参数

client_secret: 同上,类似于一种标识这个客户端的密钥

grant_type:授权模式,有4种模式,后面说

access_token : 当A服务器认真后返回给B服务器用来访问具体用户资源的凭证

refresh_token : 当access_token失效时用来刷新获取一个新的access_token

授权模式分类

授权码模式

        相对来说,操作最复杂,但是也是使用比较多的一种模式,需要分两步进行

1. 获取code授权码,伪链接如下

http:a.com/oauth/authorization?client_id=b&grant_type=code&redirect_uri=b.com/auth

B网站需要引导用户去访问A网站提供的地址,该地址A网站会让用户去登录,用户同意后那么A网站会访问redirect_uri并带上code参数到B网站上面

2. 获取token信息,伪链接如下

http:a.com/oauth/token?client_id=b&client_secret=bsecre&code=CODE

这个是后台请求的,用户是看不到的,访问这个以后如果是正常的话A网站会返回access_token和refresh_token两个token信息

3. 有了access_token之后就可以通过这个请求用户在A网站上的数据了,可以直接带在参数上也可以放在请求里

简化模式

        当网站没有后端程序的时候,就只能使用这种模式进行处理了,这种相对来说就非常简单,但是也不安全,只需要一步就可以处理

1. 直接获取token信息,伪链接如下

http:a.com/oauth/authorization?client_id=b&grant_type=token&redirect_uri=b.com/auth

返回的信息就是access_token,后续的操作就是一样的了

密码模式

        当用户足够信任网站的时候,就可以使用这种模式进行授权,跟简化模式其实差不多

1. 直接获取token信息,伪链接如下

http:a.com/oauth/authorization?&grant_type=password&username=name&password=password&redirect_uri=b.com/auth

返回的信息就是access_token,后续的操作就是一样的了

客户端模式

        跟上面两种也差不多,只不过这个权限很大,不需要用户的同意,等于你只要有client_id就可以操作用户的资源了,这种模式一般在内部使用的比较多

1. 直接获取token信息,伪链接如下

http:a.com/oauth/authorization&grant_type=client&client_id=id&client_secret=client_secret&redirect_uri=b.com/auth

返回的信息就是access_token,后续的操作就是一样的了

刷新token

        access_token 的时间总是有效的,如果每次失效就要让用户重新进行授权,对于用户来说体验多少有点不好,所以Oauth2提供了一种刷新token的机制,就是利用上面的refresh_token调用专门的接口获取新的access_token,同时旧的access_token也会被失效

结语

        以上是Oauth2的基础概念和几种基本的模式,每个网站的时候可能不太一样,不过总的原则总是需要遵循这一套标准的,具体的实现与业务相关

相关内容

热门资讯

一季度增长12.2%后,王莉定... 来源:茅台时空 据茅台官微报道,茅台酱香系列酒一季度交出营业收入78.8亿元、同比增长12.2%的成...
曦智科技沈亦晨:将与上海国资联... 曦智科技创始人、董事长沈亦晨 图片来源:主办方供图 5月10日,上海曦智科技创始人、董事长沈亦晨出现...
东实环境“还贷式IPO”困境:... 图源:图虫创意 来源|时代商业研究院 作者|特约研究员赖钧洪、郑琳 编辑|郑琳 作为东莞市国资委10...
为什么是宁波?扛起中国五金出口... 中国作为全球最大的五金制品生产国和出口国,正以绿色转型、品牌出海为方向,在全球五金供应链中占据核心地...
微信:关于开展涉税虚假宣传信息... 近期,平台接到用户投诉举报,发现个别账户发布“纳税15万,国家补贴5万”“4月恢复核定征收”等涉税虚...
央视调查:AI“买家秀”误导消... IT之家 5 月 10 日消息,据央视新闻今日报道,在网购场景中,由于消费者无法直接接触商品,所以评...
(机遇香港)“温情经济”升温 ... 中新社香港5月10日电 (记者 邱兆翔)5月10日是母亲节。在香港,不少子女与父母一早出门饮茶庆祝,...
原创 3... 5月8日,彭博社一段视频访谈把华尔街炸了。有"新债王"之称的双线资本创始人冈拉克,公开承认自己已经在...
网点关停潮?一半全国性银行机构... 营业网点是商业银行经营的最小细胞,也是直接触达客户、创造价值的核心战场,其竞争力直接关系到银行经营效...
粮农组织:战火阴影下4月全球食... 来源:财联社 联合国粮农组织(FAO)周五指出,由于中东局势紧张及霍尔木兹海峡反复被封,全球粮食价格...
原创 帮... 老铁们,帮主又来了。今天聊个事儿,保证让你觉得,原来国家战略离你的钱包可以这么近!四部门刚发了个文,...
吸引全球资本,亚洲新一轮“超级... 投资者正将目光转向亚洲,寻找全球股市上涨行情的下一个突破口。 在人工智能浪潮驱动下,韩国股市本月涨幅...
越秀区多维经营账服务细致入微的... 越秀区多维经营账服务细致入微的代理机构参考 在广州越秀区这一商贸活跃的核心区域,中小企业对财税服务...
教人挣钱的自媒体平台叫什么 教人挣钱的自媒体平台叫什么?这问题问得太到位了。说实话,我也曾经翻遍全网、踩过无数坑,就为了找一个真...
湖人被无情戏耍又是三节崩 里夫... 与雷霆的半决赛打到第三场,一种无望的情绪已彻底裹挟了湖人全队,彻底无法被摆脱了。 所有人都清楚,湖人...
原创 欧... 据环球网综合报道,欧盟正处于前所未有的抉择压力之下。在俄乌冲突延续近四年的沉重阴影下,欧盟内部关于援...
原创 1... 雷达财经出品 文|丁禹 编|孟帅 五一假期刚刚结束,市值百亿的川酒上市公司水井坊,其核心管理层再次迎...
美银Hartnett:材料板块... 美银证券首席投资策略师Michael Hartnett在最新报告中点名材料板块,称其将是下一个“牛市...
情绪消费的好日子,还剩多久 文|强调Next 2025年是中国潮玩行业最热闹的一年,也是从业者最难熬的一年。 热闹是真的热闹。...