Oauth2.0的使用QQ互联登录

2 篇文章 1 订阅

1、根据appid拼接授权链接

参数是否必须含义
response_type必须授权类型,此值固定为“code”。
client_id必须申请QQ登录成功后,分配给应用的appid。
redirect_uri必须成功授权后的回调地址,必须是注册appid时填写的主域名下的地址,建议设置为网站首页或网站的用户中心。注意需要将url进行URLEncode。
state必须client端的状态值。用于第三方应用防止CSRF攻击,成功授权后回调时会原样带回。请务必严格按照流程检查用户与state参数状态的绑定。
scope可选请求用户授权时向用户显示的可进行授权的列表。
可填写的值是API文档中列出的接口,以及一些动作型的授权(目前仅有:do_like),如果要填写多个接口名称,请用逗号隔开。
例如:scope=get_user_info,list_album,upload_pic,do_like
不传则默认请求对接口get_user_info进行授权。
建议控制授权项的数量,只传入必要的接口名称,因为授权项越多,用户越可能拒绝进行任何授权。
display可选PC网站接入时使用。
用于展示的样式。不传则默认展示为PC下的样式。
如果传入“mobile”,则展示为mobile端下的样式。

https://graph.qq.com/oauth2.0/authorize?response_type=code&client_id=*********&redirect_uri=http://www.itmayiedu.com:7070/login/oauth/callback?unionPublicId=mayikt_qq&state=test

2、授权成功之后,浏览器会自动重定向到回调地址,从回调地址中获取授权码code

http://www.itmayiedu.com:7070/login/oauth/callback?unionPublicId=mayikt_qq&code=63108962FBE21F84122D937B2761A45B&state=test

3、根据授权码获取accestoken

参数是否必须含义
grant_type必须授权类型,在本步骤中,此值为“authorization_code”。
client_id必须申请QQ登录成功后,分配给网站的appid。
client_secret必须申请QQ登录成功后,分配给网站的appkey。
code必须上一步返回的authorization code。
如果用户成功登录并授权,则会跳转到指定的回调地址,并在URL中带上Authorization Code。
例如,回调地址为www.qq.com/my.php,则跳转到:
http://www.qq.com/my.php?code=520DD95263C1CFEA087******
注意此code会在10分钟内过期。
redirect_uri必须与上面一步中传入的redirect_uri保持一致。

https://graph.qq.com/oauth2.0/token?grant_type=authorization_code&client_id=********&client_secret=*********&code=63108962FBE21F84122D937B2761A45B&redirect_uri=http://www.itmayiedu.com:7070/login/oauth/callback?unionPublicId=mayikt_qq

4、根据accessToken获取openId

参数是否必须含义
access_token必须在Step1中获取到的access token。

https://graph.qq.com/oauth2.0/me?access_token=CC586C517EA6E482C335249E1F56123E

5、根据openid获取用户信息

参数含义
access_token可通过使用Authorization_Code获取Access_Token 或来获取。 
access_token有3个月有效期。
oauth_consumer_key申请QQ登录成功后,分配给应用的appid
openid用户的ID,与QQ号码一一对应。 
可通过调用https://graph.qq.com/oauth2.0/me?access_token=YOUR_ACCESS_TOKEN 来获取。

https://graph.qq.com/user/get_user_info?access_token=CC586C517EA6E482C335249E1F56123E&oauth_consumer_key=********&openid=322CC5247D50EFA6D68296A24B2C69BB

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值