`

OAuth 授权过程

阅读更多
OAuth认证过称需要你的应用和Google的授权服务器,终端用户做一系列交互。
基本的交互过称:
   1. 你的应用从Google的授权服务器获得一个未授权的请求token
   2. Google要求用户给予你的应用访问需要的数据。比如你要访问gmail,google把页面引导到gmail的登录页面,提示用户登录,这样google就获得了用户的许可。
   3. 你的应用从Google的授权服务器得到一个授权的请求token.
   4. 你用请求token交换为一个访问token
   5. 你使用访问toaken从Google的服务访问服务器来请求数据
分享到:
评论
1 楼 javavsnet 2010-12-22  
转一个 http://ccren.blogbus.com/logs/78814344.html
OAUTH协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是OAUTH的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此OAUTH是安全的。目录OAUTH协议为用户资源的授权提供了一个安全的、开放而又简易的标准。同时,任何第三方都可以使用OAUTH认证服务,任何服务提供商都可以实现自身的OAUTH认证服务,因而OAUTH是开放的。业界提供了OAUTH的多种实现如PHP,JavaScript,Java,Ruby等各种语言开发包,大大节约了程序员的时间,因而OAUTH是简易的。目前互联网很多服务如OpenAPI,很多大头公司如Google,Yahoo,Microsoft等都提供了OAUTH认证服务,这些都足以说明OAUTH标准逐渐成为开放资源授权的标准。在官方网站的首页,可以看到下面这段简介:AnopenprotocoltoallowsecureAPIauthorizationinasimpleandstandardmethodfromdesktopandwebapplications. 大概意思是说OAUTH是一种开放的协议,为桌面程序或者基于BS的web应用提供了一种简单的,标准的方式往访问需要用户授权的API服务。OAUTH 类似于FlickrAuth、Google'sAuthSub[1]、Yahoo'sBBAuth、FacebookAuth等。OAUTH认证授权具有以下特点:1.简单:不管是OAUTH服务提供者还是应用开发者,都很轻易于理解与使用;2.安全:没有涉及到用户密钥等信息,更安全更灵活;3.开放:任何服务提供商都可以实现OAUTH,任何软件开发商都可以使用OAUTH;

典型案例:假如一个用户拥有两项服务:一项服务是图片在线存储服务A,另一个是图片在线打印服务B。如下图所示。由于服务A与服务B是由两家不同的服务提供商提供的,所以用户在这两家服务提供商的网站上各自注册了两个用户,假设这两个用户名各不相同,密码也各不相同。当用户

要使用服务B打印存储在服务A上的图片时,用户该如何处理?法一:用户可能先将待打印的图片从服务A上下载下来并上传到服务B上打印,这种方式安全但处理比较繁琐,效率低下;法二:用户将在服务A上注册的用户名与密码提供给服务B,服务B使用用户的帐号再往服务A处下载待打印的图片,这种方式效率是进步了,但是安全性大大降低了,服务B可以使用用户的用户名与密码往服务A上查看甚至篡改用户的资源。很多公司和个人都尝试解决这类题目,包括Google、Yahoo、 Microsoft,这也促使OAUTH项目组的产生。OAuth是由BlaineCook、ChrisMessina、LarryHalff及 DavidRecordon共同发起的,目的在于为API访问授权提供一个开放的标准。OAuth规范的1.0版于2007年12月4日发布。

在弄清楚OAUTH流程之前,我们先了解下OAUTH的一些术语的定义:OAUTH相关的三个URL:RequestTokenURL:获取未授权的 RequestToken服务地址;UserAuthorizationURL:获取用户授权的RequestToken服务地址;AccessTokenURL:用授权的RequestToken换取AccessToken的服务地址;OAUTH相关的参数定义:oauth_consumer_key:使用者的ID,OAUTH服务的直接使用者是开发者开发出来的应用。所以该参数值的获取一般是要往OAUTH 服务提供商处注册一个应用,再获取该应用的oauth_consumer_key。如Yahoo该值的注册地址为:https://developer.yahoo.com/dashboard /oauth_consumer_secret:oauth_consumer_key对应的密钥。oauth_signature_method:请求串的签名方法,应用每次向OAUTH三个服务地址发送请求时,必须对请求进行签名。签名的方法有:HMAC-SHA1、RSA-SHA1与 PLAINTEXT等三种。oauth_signature:用上面的签名方法对请求的签名。oauth_timestamp:发起请求的时间戳,其值是距197000:00:00GMT的秒数,必须是大于0的整数。本次请求的时间戳必须大于或者即是上次的时间戳。oauth_nonce:随机天生的字符串,用于防止请求的重放,防止外界的非法攻击。oauth_version:OAUTH的版本号,可选,其值必须为1.0。OAUTHHTTP响应代码:HTTP400BadRequest请求错误Unsupportedparameter参数错误 Unsupportedsignaturemethod签名方法错误Missingrequiredparameter参数丢失 DuplicatedOAuthProtocolParameter参数重复HTTP401Unauthorized未授权 InvalidConsumerKey非法keyInvalid/expiredToken失效或者非法的tokenInvalidsignature签名非法Invalid/usednonce非法的nonce

在弄清楚了OAUTH的术语后,我们可以对OAUTH认证授权的流程进行初步熟悉。实在,简单的来说,OAUTH认证授权就三个步骤,三句话可以概括:1.获取未授权的RequestToken2.获取用户授权的RequestToken3.用授权的 RequestToken换取AccessToken当应用拿到AccessToken后,就可以有权访问用户授权的资源了。大家肯能看出来了,这三个步骤不就是对应OAUTH的三个URL服务地址嘛。一点没错,上面的三个步骤中,每个步骤分别请求一个URL,并且收到相关信息,并且拿到上步的相关信息往请求接下来的URL直到拿到AccessToken。具体每步执行信息如下:A.使用者(第三方软件)向OAUTH服务提供商请求未授权的 RequestToken。向RequestTokenURL发起请求,请求需要带上的参数见上图。B.OAUTH服务提供商同意使用者的请求,并向其颁发未经用户授权的oauth_token与对应的oauth_token_secret,并返回给使用者。C.使用者向OAUTH服务提供商请求用户授权的RequestToken。向UserAuthorizationURL发起请求,请求带上上步拿到的未授权的token与其密钥。D.OAUTH服务提供商将引导用户授权。该过程可能会提示用户,你想将哪些受保护的资源授权给该应用。此步可能会返回授权的RequestToken也可能不返回。如 YahooOAUTH就不会返回任何信息给使用者。E.RequestToken授权后,使用者将向AccessTokenURL发起请求,将上步授权的 RequestToken换取成AccessToken。请求的参数见上图,这个比第一步A多了一个参数就是RequestToken。F.OAUTH服务提供商同意使用者的请求,并向其颁发AccessToken与对应的密钥,并返回给使用者。G.使用者以后就可以使用上步返回的AccessToken 访问用户授权的资源。从上面的步骤可以看出,用户始终没有将其用户名与密码等信息提供给使用者(第三方软件),从而更安全。用OAUTH实现背景一节中的典型案例:当服务B(打印服务)要访问用户的服务A(图片服务)时,通过OAUTH机制,服务B向服务A请求未经用户授权的RequestToken后,服务A将引导用户在服务A的网站上登录,并询问用户是否将图片服务授权给服务B。用户同意后,服务B就可以访问用户在服务A上的图片服务。整个过程服务B 没有触及到用户在服务A的帐号信息。如下图所示,图中的字母对应OAUTH流程中的字母:

===============================================

最近弄了一个项目,被这个Oauth认证被绕晕了,好不轻易跑通了逻辑,下面开始好好分析一下它的认证过程。他的认证过程简单来说可以分成3部分:

向服务器发请求,索要一个没有授权的token和它的密钥.

拿着这个没有授权的token往网站上给用户授权这个token,拿到一个权限核对码(verifier)

拿着这个核对码,往请求一个许可的token和它的密钥.

这样我们就可以访问需要授权的信息了.

固然说起来轻易,而且还有GoogleCode上的OauthApi,但是经常被那些参数弄晕,导致不能继续下往,所以首先要记住一点:XXX出现在URL中,XXX_secret就会用来做签名.

下面说说1-4步中的请求分别需要动用哪些参数。最开始,你手上会有两个参数,一个是consumerKey,另外一个是consumerSecret。

请求未授权的token和它的密钥(取名分别为t1,ts1).这里关键参数有:oauth_consumer_key=consumerKey.只用consumerSecret来签名.

给未授权token拿给授权,获得token(实在和t1是一个值)和核对码(verifier,取名为v2).这里关键参数有:oauth_token=t1,oauth_callback=callbackURL(这个用于接受返回的值的地址,它有可能会在服务器端做一次跳转).这一步不需要签名.

请求许可token和它的密钥(取名为a3和as3).这里关键参数有:oauth_consumer_key=consumerKey,oauth_token=t1,oauth_verifier=v2.用consumerSecret和ts1做签名.

访问许可的资源.这里关键参数有:oauth_consumer_key=consumerKey,oauth_token=a3.用consumerSecret和as3做签名.

3.获取终极的授权token(post):

url:http://api.t.sina.com.cn/oauth/access_token

postdata:oauth_consumer_key=consumerKey&oauth_token=t1&oauth_signature_method=HMAC-SHA1&oauth_verifier=v2&oauth_timestamp=&oauth_nonce=&oauth_signature=[consumerSecret+ts1]

返回:oauth_token=a3&oauth_token_secret=as3

至此,就完成登录并可以访问受限资源啦!

相关推荐

    新浪微博OAuth授权

    这些库提供了便捷的方法来处理OAuth授权过程中的各个环节,例如生成签名、构建请求等。 - **初始化消费者信息**:定义消费者密钥和消费者秘密。 - **请求请求令牌**:调用服务提供者提供的接口获取请求令牌。 - **...

    signpost+oauth demo

    在开始之前,你需要为你的应用获取OAuth的消费者密钥(consumer key)和秘密(consumer secret),这是在OAuth授权过程中用来识别你的应用的身份。 接下来,我们来看一下Signpost-examples-master这个压缩包中的...

    一个OAuth授权的一个例子,实现了三种常用的授权方式

    2. 授权码模式下的授权码获取和令牌交换过程。 3. 简化模式下直接在浏览器中获取访问令牌的代码。 4. 密码模式下处理用户凭据并获取令牌的函数。 5. 使用获取到的令牌进行API调用的示例。 通过分析和学习这个例子,...

    微信oauth2.0授权

    在实际的开发过程中,微信OAuth2.0通常用于实现以下功能: - 第三方登录:用户可以通过微信账号一键登录,简化注册流程。 - 用户信息同步:获取用户微信信息,用于完善用户个人资料。 - 分享功能:获取用户权限后,...

    前端开源库-oauth-signature

    这个库特别适用于前端应用,因为通常情况下,前端代码无法直接处理服务器端的安全令牌,但仍然需要参与OAuth授权过程。 首先,让我们了解一下OAuth 1.0A签名的生成步骤: 1. **构建请求参数**:包括HTTP方法(如GET...

    oauth2.0授权机制,授权码

    在这个过程中,客户端通过获取授权码(Authorization Code)来请求访问资源所有者的受保护资源。 1. **授权码模式**:这是OAuth2.0中最常见的授权类型,适用于有服务器端的应用。当用户同意授权后,授权服务器会...

    Spring cloud Oauth2使用授权码模式实现登录验证授权

    - 如果你的系统是Spring Cloud架构,可以利用Spring Cloud Security提供的OAuth2整合,简化上述过程,例如自动配置授权服务器和资源服务器。 在整个过程中,安全措施必须到位,如使用HTTPS、加密存储敏感信息等。...

    oauth2.0的授权服务

    OAuth2.0是一种广泛应用...这些代码可以帮助开发者理解OAuth2.0的实现过程,如何设置授权服务器、客户端的交互逻辑,以及如何验证和使用访问令牌。通过深入学习和实践,开发者可以更好地掌握OAuth2.0的原理和实际应用。

    jmeter 实现oauth1.0授权认证

    在这个预处理器中,我们将编写Java脚本来生成OAuth签名,这是OAuth 1.0认证过程的关键部分。 3. **Java脚本实现OAuth签名**: 参照提供的代码,可以看到以下关键组件: - 定义常量:MAC_NAME(HMAC-SHA256算法...

    街旁oauth授权认证

    1. **授权过程**: - 用户打开第三方应用,该应用请求用户的授权来访问街旁上的特定资源。 - 用户同意授权后,第三方应用会获得一个授权码。 - 应用使用授权码向街旁的授权服务器请求访问令牌(Access Token)。 ...

    oauth2全套(授权服务器+资源服务器+客户端独立版)

    OAuth2 是一个授权框架,广泛应用于现代Web应用和API的安全性设计,允许第三方应用在用户许可的情况下访问受保护的资源。本套系统包含了授权服务器、资源服务器和客户端,旨在实现安全的单点登录(Single Sign-On, ...

    PHP微信OAuth2网页授权登陆接口

    微信OAuth2网页授权登陆接口,微信OAuth2网页授权登陆接口,在你的网站上放上可以扫码登陆,会不会吸引更多用户去注册,现在你只需要简单的配制一下...将上述目录在微信中打开,就可以体验微信的OAuth2.0网页授权过程。

    springboot整合Oauth2,GateWay实现网关登录授权验证

    SpringBoot整合OAuth2和Gateway实现网关登录授权验证是一个复杂而关键的过程,它涉及到现代微服务架构中的安全性设计。OAuth2是一种授权框架,用于保护API并允许第三方应用访问受保护的资源,而Spring Gateway作为...

    OAuth 2.0授权框架.pdf

    OAuth 2.0作为一项改进技术,主要目标在于简化授权过程,同时为各种类型的客户端提供特定的授权流程。 OAuth 2.0授权框架定义了四种授权许可类型,它们分别是: 1. 授权码许可(Authorization Code) 2. 隐式许可...

    新浪微博开放平台Demo源码

    在处理OAuth授权过程中我也碰到几个在新浪开放平台论坛中常见的几个问题,在这里总结下,在后面讲解中会讲到我的想法和解决办法: 1、requesttoken时callback问题。 2、401错误。 3、403错误。 4、500错误。 5...

    YahooMailApiDemo.rar

    这个压缩包中包含了一个演示项目,它展示了如何在实际应用中实现OAuth授权过程。开发者可以通过以下步骤进行学习: 1. 注册应用:在Yahoo Developer Network(YDN)上注册一个新的应用,获取Client ID和Client ...

    微信 oauth2 授权流程 业务衔接

    本文将围绕“微信 OAuth2 授权流程 业务衔接”这一主题,详细阐述微信OAuth2授权流程的具体步骤及其实现过程中的关键环节。 #### 二、核心概念解释 **1. OAuth2:** OAuth2是一种开放标准协议,用于应用程序之间...

    sina oauth 授权

    5. **遵循Sina Weibo的开发者政策**: 遵守新浪的开放平台政策,不滥用用户数据,确保合法合规使用OAuth授权。 总结,Sina OAuth授权是Sina Weibo API开发的关键步骤,Weibo4j库则为开发者提供了便利的工具。理解并...

    IOS新浪微博Oauth2.0授权demo

    在iOS平台上实现新浪微博的OAuth2.0授权是一个常见的需求,特别是在开发社交应用或者需要与微博进行数据交互的应用中。OAuth2.0是一种授权框架,它允许第三方应用在用户许可的情况下,安全地访问用户在特定服务(如...

Global site tag (gtag.js) - Google Analytics