【QQ登录】使用Implicit_Grant方式获取Access_Token
2012-05-26 22:03
633 查看
1. 简介
即client-side模式,是OAuth2.0认证的一种模式,又称User-AgentFlow;
适用于需要通过客户端访问的方式,例如需要通过浏览器的javascript代码,或者电脑/移动终端上的客户端访问时。
其授权验证流程示意图如下(图片来源:OAuth2.0协议草案V21的4.2节 )
对于应用而言,只需要一步:构造授权地址,即可获取Access_Token。
2. 过程详解
请求地址:PC网站: https://graph.qq.com/oauth2.0/authorize
WAP网站:https://graph.z.qq.com/moc2/authorize
请求参数:
请求参数请包含如下内容:
参数 | 是否必须 | 含义 |
---|---|---|
response_type | 必须 | 授权类型,此值固定为“token”。 |
client_id | 必须 | 申请QQ登录成功后,分配给应用的appid。 |
redirect_uri | 必须 | 成功授权后的回调地址,必须是注册appid时填写的主域名下的地址,建议设置为网站首页或网站的用户中心。 |
scope | 可选 | 请求用户授权时向用户显示的可进行授权的列表。 可填写的值是【QQ登录】API文档中列出的接口,以及一些动作型的授权(目前仅有:do_like),如果要填写多个接口名称,请用逗号隔开。 例如:scope=get_user_info,list_album,upload_pic,do_like 不传则默认请求对接口get_user_info进行授权。 建议控制授权项的数量,只传入必要的接口名称,因为授权项越多,用户越可能拒绝进行任何授权。 |
state | 可选 | client端的状态值。用于第三方应用防止CSRF攻击,成功授权后回调时会原样带回。 |
display | 可选 | 仅PC网站接入时使用。 用于展示的样式。不传则默认展示为为PC下的样式。 如果传入“mobile”,则展示为mobile端下的样式。 |
g_ut | 可选 | 仅WAP网站接入时使用。 QQ登录页面版本(1:wml版本; 2:xhtml版本),默认值为1。 |
如果用户成功登录并授权,则会跳转到指定的回调地址,并在URL后加“#”号,带上Access Token以及expires_in等参数。如果redirect_uri地址后已经有“#”号,则加“&”号,带上相应的返回参数。如:
PC网站:http://graph.qq.com/demo/index.jsp?#access_token=FE04************************CCE2&expires_in=7776000
WAP网站:http://open.z.qq.com/demo/index.jsp?#access_token=FE04************************CCE2&expires_in=7776000
说明:expires_in是该access token的有效期,单位为秒。
Tips:
1. 可通过js方法:window.location.hash来获取URL中#后的参数值。
2. 建议用js设置cookie存储token。
错误码说明:
接口调用有错误时,会返回code和msg字段,以url参数对的形式返回,value部分会进行url编码(UTF-8)。
PC网站接入时,错误码详细信息请参见:100000-100031:PC网站接入时的公共返回码。
WAP网站接入时,错误码详细信息请参见:8000-8999:通过Implicit模式获取Access
Token时,发生错误。
3. 快速上手
详见:【QQ登录】开发攻略_Client-side。
相关文章推荐
- 使用AFNetWorking 实现以Basic Authentication方式获取access-token
- 使用Facebook登录过后,在退出登录的时候清除access_token
- 微信登录,获取access_token,openid 记录
- spring-oauth-server实践:使用授权方式四:client_credentials 模式下access_token做业务!!!
- ASP.NET MVC使用中转站方式获取code实现微信登录,分享功能
- 微信公共平台接入之:网页授权(微信授权,微信access_token获取,获取微信用户信息),微信开发者工具使用,微信公众平台测试号申请接入
- CURL 笔记:微信 curl 方式 获取access_token https
- Oauth支持的5类 grant_type 及说明 authorization_code — 授权码模式(即先登录获取code,再获取token) password — 密码模式(将用户名,密码传
- 微信开发使用access_token 获取微信的ip地址
- 使用QQ第三方登录时,手机应用和网站应用对同一个QQ号,获取到的openid不一样
- 新浪微博Oauth2.0授权 获取Access Token以及API的使用
- 解决QQ第三方登录出现access_token为空的情况
- QQ登录使用的g_tk获取的python代码
- 新浪授权登录 正确的获取access_token (都不能用curl请求,包括微信授权登录 ) 要用file_get_contents
- 使用UIautomator获取手机QQ登录验证码
- 模拟登录获取新浪微博的access_token
- [2018-05-27]配置VSTS认证方式使用Personal Access Token
- access_token的获取方式
- android 新浪微博登录获取access_token值的问题
- 使用QQ第三方登录时,手机应用和网站应用对同一个QQ号,获取到的openid不一样