(第三方登录)

创建应用,域名,详情请看:http://www.cnblogs.com/xujn/p/5287157.html

效果图:

把API,callback.php,qqlogin.php,图片,都放在web目录下.

第一种方法(mysql方法) call.back.php:

<?php
header('content-type:text/html;charset=utf-8');
require_once("./API/qqConnectAPI.php");
//放置按钮
$qc = new QC();
//根据code获取accesstoken
$token= $qc->qq_callback();
//根据accesstoken获取openid
$openid= $qc->get_openid();
//根据token和openid,获取用户信息
$qc = new QC($token,$openid);
$arr= $qc->get_user_info();
$nickname=$arr['nickname'];

//入库(1)
$link=mysqli_connect('localhost:3306','root','root');
mysqli_query($link,'use small2');
mysqli_query($link,'set names utf8');
$sql_openid="select * from qq where open_id='$openid'";
$db_openid=mysqli_query($link,$sql_openid);
//var_dump($db_openid);die;
$data_openid=mysqli_fetch_assoc($db_openid);
//判断用户id是否存在
if($data_openid)
{
    if($data_openid['token']==$token)
    {
         echo "<script>alert('登陆成功');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
    }
    else
    {
       $token_update="update qq set token='$token' where open_id='$openid'";
       $db_token=mysqli_fetch_assoc(mysqli_query($link,$token_update));
       if($db_token)
       {
             echo "<script>alert('登陆成功');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
       }
       else
       {
           echo "<script>alert('token修改失败');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
       }   
    }
}
else
{
    //添加
    $add_login="insert into login(u_name,pwd) values('傻瓜','123456')";
    //echo $add_login;die;
    $data_add=mysqli_query($link,$add_login);
    if($data_add)
    {
        $select_userid="select * from login order by u_id desc";
        $last_id=mysqli_fetch_assoc(mysqli_query($link,$select_userid));
        $u_id=$last_id['u_id'];
        $add_useropen="insert into qq values(null,'$nickname','$u_id','$openid','腾讯QQ','$token')";
        $db_useropen=mysqli_query($link,$add_useropen);
        if($db_useropen)
        {
            echo "<script>alert('登陆成功');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
        }
        else
        {
           echo "<script>alert('open添加失败');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
        }
    }
    else
    {
           echo "<script>alert('用户添加失败');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
    }
}
?>

第二种方法(跳转控制器):

callback.php:

$nickname=$arr['nickname'];
$all=$token.",".$openid.",".$nickname;
echo header("location:http://www.small2.com/backend/web/index.php?r=login/insert&all=$all");

控制器:

//保存第三方登录的用户信息,并验证是否成功
   public function actionInsert()
   {
      //接收token和openid
      $all=Yii::$app->request->get('all');
      //炸开字符串
      $res=explode(",",$all);
      //var_dump($res);die;
      $token=$res[0];
      $openid=$res[1];
      $nickname=$res[2];
      
      //查询openid
      $row=Yii::$app->db->createCommand("select * from qq where open_id='$openid'")->queryone();

//判断是否存在openid
      if($row['openid'])
      {
          //判断token
          if($row['token']==$token)
          {
              echo "<script>alert('登陆成功');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
          }
          else
          {
            //修改token值
             $up_token=Yii::$app->db->createCommand()->update("qq",["token"=>$token]);
             if($up_token->execute())
             {
                echo "<script>alert('登陆成功');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
             }
             else
             {
                echo "<script>alert('token修改失败');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
             }
          }
      }
      else
      {
         //随意添加一条用户信息,测试一下
         $add_user=Yii::$app->db->createCommand()->insert("login",["u_name"=>'亲爱的',"pwd"=>'123456',"email"=>'495099758@qq.com','sex'=>'男','status'=>1])->execute();
         $u_id= intval(Yii::$app->db->getLastInsertId());
         //把用户id,openid,token插入表中
         $add_qq=Yii::$app->db->createCommand()->insert("qq",["nickname"=>$nickname,"open_id"=>$openid,"token"=>$token,"u_id"=>$u_id,"from"=>'腾讯QQ']);
         if($add_qq->execute())
         {
            echo "<script>alert('登陆成功');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
         }
         else
         {
            echo "<script>alert('添加失败');location.href='http://www.small2.com/backend/web/index.php?r=login/login'</script>";
         }
      }
   }

yii框架中保存第三方登录信息的更多相关文章

  1. Yii框架中集成phprpc、hprose

    在项目开发的过程中有时候会涉及到对外提供接口供第三方程序调用或者是不同程序间需要相互通信,那么最通用的做法是用传统的SOAP方式来实现,用XML的文档格式来作为传输载体.但是这种方式不灵活,支持的数据 ...

  2. 使用Yii框架中遇到的三个问题

    以下由我们在信易网络公司开发项目的时候终结出的一些经验 使用Yii框架中遇到的三个问题 1.main.php文件中欲引入全局变量的问题 还原一下此问题:在Yii框架中,main.php一般会作为整个应 ...

  3. .NET跨平台之旅:ASP.NET Core从传统ASP.NET的Cookie中读取用户登录信息

    在解决了asp.net core中访问memcached缓存的问题后,我们开始大踏步地向.net core进军——将更多站点向asp.net core迁移,在迁移涉及获取用户登录信息的站点时,我们遇到 ...

  4. php使用session来保存用户登录信息

    php使用session来保存用户登录信息 使用session保存页面登录信息 1.数据库连接配置页面:connectvars.php <?php //数据库的位置 define('DB_HOS ...

  5. DedeCMS中实现在顶层banner中显示自定义登录信息

    一.需求描述 dedeCMS自带的模板中有互动中心模块,如下图所示: 由于会员登陆对我来说不是网站的重要模块且默认DedeCMS的会员中心模块的初始化很慢,常会显示“正在载入中,请稍候...”, 所以 ...

  6. 如何查看Firefox中保存的登录密码

    问:以前使用Firefox浏览器登录一个论坛,并且临时申请了一个账号,在使用Firefox登录时选择让它记住密码了,后来,我忘记了那个论坛的密码,但是可以使用Firefox直接登录.现在能不能查看密码 ...

  7. Yii 框架中安装 memcache 及配置和测试

    安装php_memcache.dll扩展 1.首先将php_memcache.dll文件放入E:\server\php\ext目录下 (php_memcache.dll下载地址:http://wind ...

  8. yii框架中关于控制器中filter过滤器和外部action的使用

    在yii框架中,控制器的过滤器分为执行前和执行后,这里举例是在执行控制器前的过滤. 需要在components/文件夹下定义公共的TestAction.php文件,并且实现run()方法.这个acti ...

  9. Yii框架中使用SRBAC作为权限管理模块时遇到的问题

    Yii框架中使用SRBAC作为权限管理模块时遇到的问题   看到Yii中提供RBAC的插件,SRBAC,就想用用. 结果按照手册上的安装办法,整来整去,安装完了,可就是进不了权限管理界面. 最后想到, ...

随机推荐

  1. [dpdk] 读开发指南(1)

    该文档是随着对于文档的阅读进度,不断增加的阅读笔记.主要内容以大纲为主,以及记录帮助记忆的内容. 在之后的实际应用中,也不随着不断的深入理解,逐渐丰富各大纲下面的内容. 1. 前期准备:设置两个环境变 ...

  2. 【C51】单片机中断

    引言 其实人的一生和单片机的运行很类似.就拿人的一生来说:有些事只需要做一次,比如得了水痘以后,体内产生免疫,以后就不会再生这个病了.有些事需要反复做,比如反复读书,反复工作,反复与困苦打交道,反复地 ...

  3. Qt数据库操作(qt-win-commercial-src-4.3.1,VC6,Oracle,SQL Server)

    qt-win-commercial-src-4.3.1.qt-x11-commercial-src-4.3.1Microsoft Visual C++ 6.0.KDevelop 3.5.0Window ...

  4. Wordpress更改后台地址

    wordpress默认的后台地址是 xx/wp-admin  或xx/wp-login.php ,谁都知道感觉很不安全, 方法一:使用插件 通过插件在地址上加上只有你知道的参数才能访问 1.后台搜索插 ...

  5. 一本很不错的书----DOOM启示录

    强推,所有玩游戏的和做游戏的热爱游戏的都应该看看. 摘录了一些话. 盖茨不明白,为什么啊为什么,为什么一个麦斯奎特的小公司,居然能从他手下挖走迈克尔·亚伯拉什,而且仅仅凭借几个游戏就胜过了自己的软件帝 ...

  6. Ajax无刷新提交

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. JS实现一个简单的计算器

    使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除.效果如上: 第一步: 创建构建运算函数count(). 第二步: 获取两个输入框中的值和获取选择 ...

  8. Objdump-查看汇编指令

    作用 Objdump可以用来看汇编指令 查看汇编指令 测试文件 编译指令 gcc -g -o objtest 1.8.c objdump -S objtest |more /main 查看结果

  9. Linux命令行–初识Linux shell

    shell及脚本简介  GNU/Linux shell 是个交互工具,它为用户提供了启动程序.管理文件系统上的文件以及管理运行在Linux系统上的进程的途径 . shell的核心是命令行提示符 它是s ...

  10. Oracle导入中文乱码解决办法

    Oracle导入中文乱码解决办法 一.确保各个客户端字符集的编码同服务器字符集编码一致 1-       确定sqlplus字符集编码,如果是windows设置环境变量. 2-       确保Sec ...