基于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. pandas基础整理

    用jupyter写好,直接放到GitHub上面了→_→ 博客链接:https://douzujun.github.io/page/%E6%95%B0%E6%8D%AE%E6%8C%96%E6%8E%9 ...

  2. ASP.NET对无序列表批量操作的三种方法

    在网页开发中,经常要用到无序列表.事实上在符合W3C标准的div+css布局中,无序列表被大量使用,ASP.NET虽然内置了BulletedList控件,用于创建和操作无序列表,但感觉不太好用.本篇介 ...

  3. jQuery精仿手机上的翻牌效果菜单

    代码简介: jQuery精仿手机上的翻牌效果菜单,很平滑的动画翻牌效果,每点击一下菜单,就会翻去一下,貌似很灵敏的动作.注意:如果预览时没看到效果,请刷新一下页面,让jquery载入就行了,在实际使用 ...

  4. 最小主义:我的Musca桌面环境

    我现在有一个非常简单实用的桌面环境了:Musca + conky + trayer. 当然Musca运行时需要dmenu,其实也不是非dmenu不可,据说 dzen 也不错. 我现在用的是dmenu. ...

  5. 21、List遍历时修改元素的问题

    List迭代时修改元素的问题 请编写代码完成以下需求:判断一个List里面是否包含monkey,如果包含的话,向集合中添加1024这个字符串.‘ package com.monkey1024.list ...

  6. 快速修改Matlab默认启动路径(Windows/Mac)

    如何修改Matlab启动路径/Windows or Mac 控制台内输入一下两行命令,之后重启MATLAB即可   newpath = '你所要设定的路径'; userpath(newpath)   ...

  7. 【多视图几何】TUM 课程 第1章 数学基础:线性代数

    在 YouTube 上找到了慕尼黑工业大学(Technische Universitaet München)计算机视觉组 Daniel Cremers 教授的 Multiple View Geomet ...

  8. iframe测试

    iframe类似于frameset,iframe 和 frameset 都用于html页面的框架布局.(都可用于后台管理界面,iframe放于body标签内,frameset不能放在body标签) 1 ...

  9. Spring4笔记2--Spring的第一个程序

    Spring程序开发: 1. 导入jar包(略) 2. 创建Spring配置文件: Spring 配置文件的文件名可以随意,但 Spring 建议的名称为 applicationContext.xml ...

  10. AndroidManifest.xml权限设置

      访问登记属性 android.permission.ACCESS_CHECKIN_PROPERTIES ,读取或写入登记check-in数据库属性表的权限 获取错略位置 android.permi ...