基于Thinkphp3.2的qq第三方oauth认证登录扩展类,
由于腾讯oauth sdk写的太多,不能与thinkphp和好的结合,最终想法讲腾讯oauth sdk写成tp的扩展类
先看代码,将代码保存在/library/org/util/Qqconnect.class.php文件中
在__construct方法中你可以直接写你的app_id、app_key和回调地址
也可以根据自己的喜好,改一下代码传参或者写到配置文件。
调用方法:1. 在qq的登录按钮的方法中调用getAuthCode方法
例如:
$qqobj=new \Org\Util\Qqconnect();
$qqobj->getAuthCode();

2.在回调地址的方法中调用getUsrInfo方法
例如:
$qqobj=new \Org\Util\Qqconnect();
$result=$qqobj->getUsrInfo();
就可以了

3.getAuthCode方法中的参数scope根据自身需要添加值get_user_info,list_album,upload_pic,do_like。

  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Copyright (c) 2015.
  4. // +----------------------------------------------------------------------
  5. // |
  6. // +----------------------------------------------------------------------
    1. namespace Org\Util;
    2. /**
    3. *  qq第三方登录认证
    4. */
    5. class Qqconnect {
    6. private static $data;
    7. //APP ID
    8. private $app_id="";
    9. //APP KEY
    10. private $app_key="";
    11. //回调地址
    12. private $callBackUrl="";
    13. //Authorization Code
    14. private $code="";
    15. //access Token
    16. private $accessToken="";
    17. public function __construct(){
    18. $this->app_id="";
    19. $this->app_key="";
    20. $this->callBackUrl="";
    21. //检查用户数据
    22. if(empty($_SESSION['QC_userData'])){
    23. self::$data = array();
    24. }else{
    25. self::$data = $_SESSION['QC_userData'];
    26. }
    27. }
      1. //获取Authorization Code
      2. public function getAuthCode(){
      3. $url="https://graph.qq.com/oauth2.0/authorize";
      4. $param['response_type']="code";
      5. $param['client_id']=$this->app_id;
      6. $param['redirect_uri']=$this->callBackUrl;
      7. //-------生成唯一随机串防CSRF攻击
      8. $state = md5(uniqid(rand(), TRUE));
      9. $_SESSION['state']=$state;
      10. $param['state']=$state;
      11. $param['scope']="get_user_info";
      12. $param =http_build_query($param,'','&');
      13. $url=$url."?".$param;
      14. header("Location:".$url);
      15. }
      16. //通过Authorization Code获取Access Token
      17. private function getAccessToken(){
      18. $url="https://graph.qq.com/oauth2.0/token";
      19. $param['grant_type']="authorization_code";
      20. $param['client_id']=$this->app_id;
      21. $param['client_secret']=$this->app_key;
      22. $param['code']=$this->code;
      23. $param['redirect_uri']=$this->callBackUrl;
      24. $param =http_build_query($param,'','&');
      25. $url=$url."?".$param;
      26. return $this->getUrl($url);
      27. }
      28. //获取openid
      29. private function getOpenID(){
      30. $rzt=$this->getAccessToken();
      31. parse_str($rzt,$data);
      32. $this->accessToken=$data['access_token'];
      33. $url="https://graph.qq.com/oauth2.0/me";
      34. $param['access_token']=$this->accessToken;
      35. $param =http_build_query($param,'','&');
      36. $url=$url."?".$param;
      37. $response=$this->getUrl($url);
      38. //--------检测错误是否发生
      39. if(strpos($response, "callback") !== false){
      40. $lpos = strpos($response, "(");
      41. $rpos = strrpos($response, ")");
      42. $response = substr($response, $lpos + 1, $rpos - $lpos -1);
      43. }
      44. $user = json_decode($response);
      45. if(isset($user->error)){
      46. exit("错误代码:100007");
      47. }
      48. return $user->openid;
      49. }
      50. //获取信息
      51. public function getUsrInfo(){
      52. if($_GET['state'] != $_SESSION['state']){
      53. exit("错误代码:300001");
      54. }
      55. $this->code=$_GET['code'];
      56. $openid=$this->getOpenID();
      57. if(empty($openid)){
      58. return false;
      59. }
      60. $url="https://graph.qq.com/user/get_user_info";
      61. $param['access_token']=$this->accessToken;
      62. $param['oauth_consumer_key']=$this->app_id;
      63. $param['openid']=$openid;
      64. $param =http_build_query($param,'','&');
      65. $url=$url."?".$param;
      66. $rzt=$this->getUrl($url);
      67. return $rzt;
      68. }
      69. //CURL GET
      70. private function getUrl($url){
      71. $ch = curl_init($url);
      72. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
      73. curl_setopt($ch, CURLOPT_TIMEOUT, 5);
      74. if (!empty($options)){
      75. curl_setopt_array($ch, $options);
      76. }
      77. $data = curl_exec($ch);
      78. curl_close($ch);
      79. return $data;
      80. }
      81. //CURL POST
      82. private function postUrl($url,$post_data){
      83. $ch = curl_init();
      84. curl_setopt($ch, CURLOPT_POST, 1);
      85. curl_setopt($ch, CURLOPT_URL, $url);
      86. curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
      87. ob_start();
      88. curl_exec($ch);
      89. $result = ob_get_contents();
      90. ob_end_clean();
      91. return $result;
      92. }
      93. }

基于Thinkphp3.2的qq第三方oauth认证登录扩展类的更多相关文章

  1. 第三方OAuth授权登录,QQ、微信(WeChat)、微博、GitHub、码云(Gitee)、淘宝(天猫)、微软(Microsoft )、钉钉、谷歌(Google)、支付宝(AliPay)、StackOverflow

    Netnr.Login 第三方OAuth授权登录 支持第三方登录 三方 参考文档 参考文档 参考文档 参考文档 参考文档 参考文档 参考文档 参考文档 参考文档 参考文档 参考文档 参考文档 安装 ( ...

  2. laravel 的passport Oauth 认证登录请求 的 oauth_token 重置

    laravel 的passport Oauth 认证登录请求 的 oauth_token 重置    使用API登录认证是需要获取访问令牌,方法为: 参数: grant_type —— 密码模式固定为 ...

  3. 实现OAUTH协议 实现 QQ 第三方登录效果

    1.OAuth的简述 OAuth(Open Authorization,开放授权)是为用户资源的授权定义了一个安全.开放及简单的标准,第三方无需知道用户的账号及密码,就可获取到用户的授权信息,并且这是 ...

  4. 一步一步搭建 OAuth 认证服务器

    http://www.fising.cn/2011/03/%E4%B8%80%E6%AD%A5%E4%B8%80%E6%AD%A5%E6%90%AD%E5%BB%BA-oauth-%E8%AE%A4% ...

  5. Oauth认证简介

    Oauth是什么: 1.Oauth是一种安全认证的协议: 2.Oauth为用户资源的授权提供了一个安全的.开放而又简易的标准: 3.Oauth的授权不会使第三方触及到用户的账号信息(用户名和密码). ...

  6. 服务端API的OAuth认证实现

    http://stackoverflow.com/questions/12499602/body-joints-angle-using-kinect?rq=1 新浪微博跟update相关的api已经挂 ...

  7. Oauth认证协议

    原文地址腾讯QQ第三方登录的实现原理? Oauth当中的角色: 1.Service Provider(服务提供方): 服务提供方通常是网站,在这些网站当中存储着一些受限制的资源,如照片.视频.联系人列 ...

  8. 基于Springboot集成security、oauth2实现认证鉴权、资源管理

    1.Oauth2简介 OAuth(开放授权)是一个开放标准,允许用户授权第三方移动应用访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方移动应用或分享他们数据的所有内容,OAu ...

  9. Android OAuth认证

    OAuth认证 为了安全地访问在线服务,用户需要在服务上进行身份验证,即要提供他们的身份的证明.对于一个要访问第三方服务的程序来说,安全问题甚至更复杂.不仅仅是用户需要在访问服务前要进行身份验证,而且 ...

随机推荐

  1. mysql自学路线

    入门: -Head First:PHP & MySQL.Lynn Beighley -MySQL必知必会 -MySQL5.5从零开始学.刘增杰 -MYSQL完全手册 (the Complete ...

  2. Spyder简述

    导言 想打造轮子, 就必须要有一套完善的造轮子的工具. 我在jupyter+sciTE的组合里转来转去, 最后还是打算放弃这个组合, 因为离开了自动完成/调用提示/随时随地的访问文档帮助, 前行之路太 ...

  3. 关于安装在win10上的oracle10g 兼容性问题

    首先在安装过程中会出现一次报错,在安装的时候 安装好了以后,准备敲击命令如果出现闪退,即是兼容性问题,下面继续设置兼容性问题 然后右键----属性----兼容性,勾上以兼容性运行即可

  4. Intellij IDEA 2017 控制台打印换行

    Intellij IDEA 2017 控制台打印的内容超过屏幕宽度了,请问怎么自动换行? 记得重启idea

  5. [整理]SQL Server Reporting Services Charts

    http://msdn.microsoft.com/zh-cn/library/aa964128.aspx#mainSectionhttp://msdn.microsoft.com/en-us/lib ...

  6. [转载]AMD 的 CommonJS wrapping

    https://www.imququ.com/post/amd-simplified-commonjs-wrapping.html 它是什么? 为了复用已有的 CommonJS 模块,AMD 规定了 ...

  7. Bzoj1939 [Croatian2010] Zuma

    Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 43  Solved: 31 Description 有一行 N 个弹子,每一个都有一个颜色.每次可以让超过 ...

  8. numpy 矩阵操作

    numpy 对矩阵对角线.上三角.下三角以及它们所在位置索引的提取 import numpy as np a = np.random.randint(0,10,[5,5]) print(a) # c ...

  9. Understanding the Space Used by ZFS -- (转)

    Understanding the Space Used by ZFS By Brian Leonard on Sep 28, 2010 Until recently, I've been confu ...

  10. const与指针

    C++中const与指针 1.常指针: ; int * const pInt = &x; 其中PInt是常指针,pInt的值无法改变,但其指向的内容可以改变. 2.指向常量的指针 有两种写法: ...