QQ授权登陆

QQ授权登录

QQ授权登陆过程总结:

第一步:获取Authorization Code

请求地址:https://graph.qq.com/oauth2.0/authorize?

参数列表:

response_type true 授权类型,此值固定为“code”。
client_id true 申请QQ登录成功后,分配给应用的appid。
redirect_uri true 成功授权后的回调地址,必须是注册appid时填写的主域名下的地址,建议设置为网站首页或网站的用户中心。注意需要将url进行URLEncode。
state true client端的状态值。用于第三方应用防止CSRF攻击,成功授权后回调时会原样带回。
scope opt 可填写的值是API文档中列出的接口,以及一些动作型的授权(目前仅有:do_like),如果要填写多个接口名称,请用逗号隔开。

例如:scope=get_user_info,list_album,upload_pic,do_like

不传则默认请求对接口get_user_info进行授权。

display true 固定值 "mobile"

演示:https://graph.qq.com/oauth2.0/authorize?response_type=code&client_id=101181432&redirect_uri=http%3A%2F%2Fios.18idc.ml%2Ftest.html&state=test&display=mobile

注意:这里的redirect_uri不是随便填的在注册时直接填写域名ex:baidu.com,用的时候http://www.baidu.com/**.**   后边的***  是某个文件这个 你自己看着办。

返回:这个你点这个链接授权后会有返回,注意记住其中的code的值;

第二步:通过Authorization Code获取Access Token

地址:https://graph.qq.com/oauth2.0/token?

参数列表:

grant_type true 授权类型,在本步骤中,此值为“authorization_code”。
client_id true 申请QQ登录成功后,分配给网站的appid。
client_secret true 申请QQ登录成功后,分配给网站的appkey。
code true 上一步返回的authorization code。

 

如果用户成功登录并授权,则会跳转到指定的回调地址,并在URL中带上Authorization Code。

例如,回调地址为www.qq.com/my.php,则跳转到:

http://www.qq.com/my.php?code=520DD95263C1CFEA087******

注意此code会在10分钟内过期。

redirect_uri true 与上面一步中传入的redirect_uri保持一致。

演示:https://graph.qq.com/oauth2.0/token?grant_type=authorization_code&client_id=****&client_secret=********&code=*******&redirect_uri=http%3A%2F%2Fios.18idc.ml%2Ftest.html

返回:接下来的不会有演示了,这个牵扯到安全问题了,要想测试请自行申请,你们用的时候肯定不会成功code早过期了,请替换参数,返回的结果包含:access_token=******&expires_in=****&refresh_token=***

access_token 授权令牌,Access_Token。
expires_in 该access token的有效期,单位为秒。
refresh_token 在授权自动续期步骤中,获取新的Access_Token时需要提供的参数。

第三步:根据access_token获取OpenID

地址:https://graph.qq.com/oauth2.0/me?

参数列表:

access_token true 在Step1中获取到的access token。

演示:这个不太好

第四步:获取用户信息

地址:https://graph.qq.com/user/get_user_info?

实例:

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

参数:access_token这个不说大家也知道,oauth_consumer_key这个其实是  appid 呵呵  是不是有点坑openID上一步获取的。

完整文档参考地址:请点击

注意: 不需要很多的类库 全部下来只有三个文件 。一个类库和两个前台页面,你将类库放到AppCode下面。然后将账号绑定那一块注释掉就行了,或者将账号绑定部分换成你自己系统的。就可以了。程序报错可能是因为我在绑定账号那里用到了别的类,你注释掉就行了 ------------------------------------------------------------ 经过两天的努力 已经成功将QQ登录集成到了 城记网 上。感谢腾讯提供的帮助文档,和关键时刻给的技术支持。我的网站是asp.net写的,有需要的网友可以联系我。 呵呵。(尽管是垃圾站,只要你愿意,又有什么关系呢?) QQ Oauth 只提供PHP的接入demo ,针对 ASP.net 的只有一个网友开发的SDK包,下载地址还老打不开,后来我从优快云上下载了一个,看了以后感觉太复杂了,我个人感觉做这么个小事情不需要搞个SDK出来,不如自己按帮助文档去写,这样自己写的方法灵活性就高一些,于是就按文档学习开发。其实文档写得很清晰,耐心一看就明白了。 不讲太多的郁闷的过程了,直接说解决办法。 办这个事情主要要知道下面几个事情。 两个重点(如下): 第一个重点:请求Token的步骤, 1:请求未授权的临时token。请求成功以后会转到QQ登录页面。 2:请求已授权的临时token。登陆成功以后获得。 3:请求已授权的Access token。 第二个重点:签名的算法。 签名的值计算有一个指定的规则,请参考腾讯开放社区帮助文档,这是最 好的资料。 注意点: 没有申请APPID和APPKEY的先去申请。 传递的每一参数都要URLENcode,注意是每一个,包括动态生成的签名。    参数之间是有顺序的,是升序排列的,无论有多少个,都要排序。    各个步骤之间是有关联的,下一步的提交往往需要上一步的返回参数。 我采取的文档结构: 总共三个文件 ,非常简单。 一个放在APPcode下面的类。用来发送请求和接待参数。 两个前台页面,主要是对类的调用。 下面把类的代码完全贴出,你知要一看见类,就知道怎么写前台页面了,很简单
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值