phpcmsV9使用的QQ登陆依然是OAuth1.0,但现在腾讯已经不审核使用OAuth1.0的网站了。这对于使用pc的站长来讲是一个无比巨大的坑。经过对phpcms论坛的一位同学做的插件进行修改,现在完美实现QQ登陆,暂无发现bug。测试网站:http://www.zuzwn.com

实现步骤:

①打开\phpcms\modules\member\index.php文件,把下面的代码找个地方塞进去(可以直接在pc默认的QQ登陆下面)。

 
  1. //QQ登陆oAuth2.0

  2. ublic function public_qq_login2(){

  3. $appid = pc_base::load_config('system', 'qq_appid');

  4. $appkey = pc_base::load_config('system', 'qq_appkey');

  5. $callback = pc_base::load_config('system', 'qq_callback');

  6. pc_base::load_app_class('qqOAuth2','',0);

  7. $info = new qqOAuth2($appid,$appkey,$callback);

  8. $this->_session_start();

  9. if (!isset($_GET['code'])){

  10. $info->redirect_to_login();

  11. }else{

  12. $code = $_GET['code'];

  13. $_SESSION['openid'] = $info->get_openid($code);//调取QQ openid值

  14. if(!emptyempty($_SESSION['openid'])){

  15. $r = $this->db->get_one(array('connectid'=>$_SESSION['openid'],'from'=>'qq'));

  16. if(!emptyempty($r)){

  17. //QQ已存在于数据库,则直接转向登陆操作

  18. $password = $r['password'];

  19. $this->_init_phpsso();

  20. $synloginstr = $this->client->ps_member_synlogin($r['phpssouid']);

  21. $userid = $r['userid'];

  22. $groupid = $r['groupid'];

  23. $username = $r['username'];

  24. $nickname = emptyempty($r['nickname']) ? $username : $r['nickname'];

  25. $this->db->update(array('lastip'=>ip(), 'lastdate'=>SYS_TIME, 'nickname'=>$me['name']),array('userid'=>$userid));

  26. if(!$cookietime) $get_cookietime = param::get_cookie('cookietime');

  27. $_cookietime = $cookietime ? intval($cookietime) : ($get_cookietime ? $get_cookietime : 0);

  28. $cookietime = $_cookietime ? TIME + $_cookietime : 0;

  29. $phpcms_auth_key = md5(pc_base::load_config('system', 'auth_key').$this->http_user_agent);

  30. $phpcms_auth = sys_auth($userid."\t".$password, 'ENCODE', $phpcms_auth_key);

  31. param::set_cookie('auth', $phpcms_auth, $cookietime);

  32. param::set_cookie('_userid', $userid, $cookietime);

  33. param::set_cookie('_username', $username, $cookietime);

  34. param::set_cookie('_groupid', $groupid, $cookietime);

  35. param::set_cookie('cookietime', $_cookietime, $cookietime);

  36. param::set_cookie('_nickname', $nickname, $cookietime);

  37. $forward = isset($_GET['forward']) && !emptyempty($_GET['forward']) ? $_GET['forward'] : 'index.php?m=member&c=index';

  38. showmessage(L('login_success').$synloginstr, $forward);

  39. }else{

  40. //未存在于数据库中,跳去完善资料页面。页面预置用户名(QQ返回是UTF8编码,如有需要进行转码)

  41. $user = $info->get_user_info();

  42. $_SESSION['connectid'] = $_SESSION['openid'];

  43. $_SESSION['from'] = 'qq';

  44. if(CHARSET != 'utf-8') {//转编码

  45. $connect_username = iconv('utf-8', CHARSET, $user['nickname']);

  46. }

  47. include template('member', 'connect');

  48. }

  49. }

  50. }

  51. }

②把附件的qqOAuth2.class.php文件放在 \phpcms\modules\member\classes\ 文件夹里。

③在后台找到connect设置,把QQ号码登陆的回调地址改成http://php100.com/index.php?m=member&c=index&a=public_qq_login2 (把我的域名换成你自己的)

④填好App ID和App key,然后更新缓存。

⑤登陆phpmyadmin,找到v9_member这张表的connectid字段(或者自定义的字段),把类型改成“char(255)”,因为phpcms默认是15位的。所以我们直接彻底修改成255位,这个不管是腾讯的其它第三方网站帐号(例如淘宝、支付宝、百度、360等其它第三方帐号),都可以完成数据绑定

phpcms V9实现QQ登陆OAuth2.0的更多相关文章

  1. QQ互联OAuth2.0 .NET SDK 发布以及网站QQ登陆示例代码(转)

    OAuth: OAuth(开放授权)是一个开放标准,允许用户授权第三方网站访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方网站或分享他们数据的所有内容. QQ登录OAuth2 ...

  2. QQ互联OAuth2.0 .NET SDK 发布以及网站QQ登陆示例代码

    OAuth: OAuth(开放授权)是一个开放标准,允许用户授权第三方网站访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方网站或分享他们数据的所有内容. QQ登录OAuth2 ...

  3. 什么是“QQ登录OAuth2.0”

    1. 什么是“QQ登录OAuth2.0 OAuth: OAuth(开放授权)是一个开放标准,允许用户授权第三方网站访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方网站或分享他 ...

  4. PHP 接入(第三方登录)QQ 登录 OAuth2.0 过程中遇到的坑

    前言 绝大多数网站都集成了第三方登录,降低了注册门槛,增强了用户体验.最近看了看 QQ 互联上 QQ 登录的接口文档.接入 QQ 登录的一般流程是这样的:先申请开发者 -> 然后创建应用(拿到一 ...

  5. Oauth2.0 QQ&微信&微博实现第三方登陆

    一.写在前面 目前对于大多数的App或Web网站都支持有第三方登陆这个功能,用户可使用 QQ/ 微信/ 微博 帐号快速登录你的网站,降低注册门槛,为你的网站带来海量新用户.最近在新项目上刚好用到了,在 ...

  6. 第三方登录:QQ登录实现(OAuth2.0)

    一.创建应用 1.在 QQ互联 创建应用 地址:https://connect.qq.com/manage.html#/ 然后进行实名认证,创建应用,审核通过 然后点击查看,可以获得 APP ID 和 ...

  7. QQ登录整合/oauth2.0认证-02-跳转到QQ互联页

    ---------------------------目录---------------------------------- QQ登录整合/oauth2.0认证-01-申请appkey和appid ...

  8. 那些年,我们开发的接口之:QQ登录(OAuth2.0)

    那些年,我们开发的接口之:QQ登录(OAuth2.0) 吴剑 2013-06-14 原创文章,转载必须注明出处:http://www.cnblogs.com/wu-jian 前言 开发这些年,做过很多 ...

  9. QQ登录(OAuth2.0)

    QQ登录(OAuth2.0) 那些年,我们开发的接口之:QQ登录(OAuth2.0) 吴剑 2013-06-14 原创文章,转载必须注明出处:http://www.cnblogs.com/wujian ...

随机推荐

  1. ubuntu下如何查看用户登录及系统授权相关信息【转】

    转自:http://www.tuicool.com/articles/ia67Bj 如何在ubuntu下查看相关用户登录历史,进行系统的日志跟踪和分析,以便发现系统登录问题,进行安全策略防护呢?ubu ...

  2. MTK6577+Android环境变量

    1. 环境变量机器对应的路径 $project = hsimobile77_ics2 $platform=mt6577 $(PRODUCT_OUT)=\out\target\product\$proj ...

  3. webhdfs追加写HDFS异常

    问题 {:timestamp=>"2015-03-04T00:02:47.224000+0800", :message=>"Retrying webhdfs ...

  4. 基于UltraVNC实现客户端远程控制

    前言 一般远程就直接用windows自带的,配置好动态IP花生壳,在任何地方都可以连回机子.最近项目里遇到这么个情况,需要快速接入远程控制功能,客户机的IP每次都会变,并且都是在外网,这样,就必须使用 ...

  5. 推荐开源Api文档生成工具——Doxygen

    http://www.stack.nl/~dimitri/doxygen/index.html 非常的方便. 2步生成API文档. 具体信息见官网哟!

  6. tomcat下jndi的三种配置方式

    jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API.命名服务将名称和对象联系起来,使得我们可以用 ...

  7. git remotes

    简单地说,一个remote repository是一个非本地的repo.它可以是在你公司网络上的另外一个git repo,也可以是在internet上,甚至在你本地文件系统中的一个repo,关键点是它 ...

  8. linux字符驱动程序结构

    linux内核为字符设备的驱动程序设计,提供了一些数据结构,和函数,供开发人员调用,将设备驱动程序注册到内核去.现代操作系统几乎都不直接和硬件通信,而是通过定义的接口,是硬件厂商自己来开发符合标准某个 ...

  9. Quickhit快速击键

    一.项目分析 根据输入速率和正确率将玩家分为不同等级,级别越高,一次显示的字符数越多,玩家正确输入一次的得分也越高.如果玩家在规定时间内完成规定次数的输入,正确率达到规定要求,则玩家升级.玩家最高级别 ...

  10. request.getRequestDispatcher()和response.sendRedirect()

    request.getRequestDispatcher("/homeMainAction_mainUI.do").forward(getRequest(), getRespons ...