这里,仓鼠将手把手记录下来实现第三方登录的流程,这里以百度为例

  

  百度开发者中心-官方网址:传送门

  所有第三方接口都不支持本地调试,只有真实的项目和服务器才有可能申请成功。
  所以申请的资料全部都要填写真实的项目信息。

1、先注册一个百度开发者账号。
2、然后进入应用管理中心,新建一个工程。

3、然后再设置工程相关的配置参数。

到这里,百度的第三方登录接口已经算是申请成功得了。下面我们就来学习如何运用PHP(基于ThinkMIMI的代码),实现第三方登录的功能。

到这一步我们先来看看百度官方的接口文档:传送门

里面提到了我们需要引导用户跳转到一个百度的URL(通过一个a标签进行跳转),这个URL里带有一个回调(也就是用户授权后,要跳转的地址)的URL地址,用户在百度中登录完成后,会自动跳转回该回调地址中,并带上一个CODE参数(形式:回调地址?code参数值),
我们拿到这个CODE参数后再去获取百度的Access_Token,最后再用这个Access_Token去获得用户的相关信息。

实践:

1、我们现在C层创建一个方法,方法里面放入引导用户去授权的URL:

例如:我有个ThirdParty的控制器,里面专门做第三方登录的

namespace app\admin\controller;                 // 本类的文件位置
use mimi\Controller; // 调用controller类
use mimi\Db; // 调用Db类
use app\admin\model\ThirdParty as Third;
use app\admin\model\Site;
use mimi\extend\Request;
use mimi\extend\Session; class ThirdParty extends Controller {
/**
* 引导用户去第三方百度进行登录授权
*/
public function baidu() {
header("location:https://openapi.baidu.com/oauth/2.0/authorize?response_type=code&client_id=你自己的API_KEY&redirect_uri=你想回调的地址&display=popup");
}

2、V层只要做一个a标签,href跳转到上面的C层方法中就可以

<?php
$baiduLoginUrl = ROOT_PATH.'index.php/admin/ThirdParty/baidu'; // 第三方登录页面
?> <a href="<?php echo $baiduLoginUrl; ?>" style="color: #ea5413; font-size: 15px;"> 百度登录</a>

效果:

当登录并授权后,将会跳回到你输入的回调地址:

这里例如回调地址为:https://ljjpm.com/index.php/admin/ThirdParty/getBaidu

那么,我们就需要在回调地址中输入内容:

C层的getBaidu():

  /*
* 获取access_token,进行登录注册处理
*/
public function getBaidu() {
$code = Request::get('code');
# 这个链接地址必须是当前回调链接地址,并且不带?参数。
$redirect_uri = 'https://ljjpm.com/index.php/admin/ThirdParty/getBaidu';
$client_secret = "你的secret_key值";
$client_id = "你的api_key值";
$url = "https://openapi.baidu.com/oauth/2.0/token?grant_type=authorization_code&code=$code&client_id=$client_id&client_secret=$client_secret&redirect_uri=$redirect_uri";
# 发送CURL,获得Access_Token
$res = Request::https_request($url);
$data = json_decode($res, true);
if (empty($data['access_token'])) {
$this->error('百度授权异常!', '/');
} # 发送CURL,获得百度用户的信息
$url = 'https://openapi.baidu.com/rest/2.0/passport/users/getInfo?access_token='.$data['access_token'];
$res = Request::https_request($url);
$data = json_decode($res, true); if (empty($data['username'])) {
$this->error('百度用户信息获取失败!', '/');
} else {
# 一般情况下呢,第三方回调都会有个userid,这是你用来区别下一次登录时,这个账号是否有注册过,如果没有则重新注册并直接登录。
$userid = $data['userid'];
$name = $data['username']; # 查询数据库,看是否有注册过
$info = Db::name('user')->where(['id' => ['=', $userid]])->find(); # 存在,直接登录
if ($info) {
# 将数据放在session中
  Session::set('loginData', $info);
Site::redirect('登录成功', 'https://ljjpm.com/index.php/admin/home/index');
exit;
} else {
# 不存在,注册再直接登录
# 先用昵称查询看看有没有被注册,被注册的话,则使用userid做用户名
$res = Db::name('user')->field('id')->where(['username' => ['=', $name]])->find(); if ($res) {
$name = $userid;
}
$time = time();
$data = [
      'id' => $userid,
'username' => $name,
];
$id = Db::name('user')->data($data)->insert();
if ($id) {
$data['u_id'] = $id;
      Session::set('loginData', $data);
      Site::redirect('登录成功', 'https://ljjpm.com/index.php/admin/home/index');
      exit;
}
$this->error('注册失败!', '/');
}
}
}

上面所提到的Request::https_request()代码为:

/*
* 接口数据传输的万能函数
*/
public static function https_request($url, $data = null){
# 初始化一个cURL会话
$curl = curl_init();
//设置请求选项, 包括具体的url
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE); //禁用后cURL将终止从服务端进行验证
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
if (!empty($data)){
curl_setopt($curl, CURLOPT_POST, 1); //设置为post请求类型
curl_setopt($curl, CURLOPT_POSTFIELDS, $data); //设置具体的post数据
}
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$response = curl_exec($curl); //执行一个cURL会话并且获取相关回复
curl_close($curl); //释放cURL句柄,关闭一个cURL会话
return $response;
}

以上就是整个第三方登录的过程啦

注意:

因为我们是通过百度来获取用户信息的,所以用户的密码肯定是拿不到得啦,这时候我们拿到的基本上是用户的userid和用户名,

那么我们的数据库上就存有id和用户名就好啦,下次再判断的时候,直接查询数据库的id即可,因为一个用户只有一个单独的userid返回

END

PHP:通过MVC,实现第三方登录(百度)的更多相关文章

  1. 第三方登录(2)Android客户瑞上第三方登录百度教程

    1,在 http://developer.baidu.com/  注册成开发者 不注册看不到开发相关的链接地址.点自己的用户名,在弹出菜单显示有 <用户中心> ,没有就是没注册. 2,找到 ...

  2. 实现QQ、微信、新浪微博和百度第三方登录(Android Studio)

    前言: 对于大多数的APP都有第三方登录这个功能,自己也做过几次,最近又有一个新项目用到了第三方登录,所以特意总结了一下关于第三方登录的实现,并拿出来与大家一同分享: 各大开放平台注册账户获取AppK ...

  3. Android 实现QQ、微信、新浪微博和百度第三方登录

    前言: 对于大多数的APP都有第三方登录这个功能,自己也做过几次,最近又有一个新项目用到了第三方登录,所以特意总结了一下关于第三方登录的实现,并拿出来与大家一同分享: 各大开放平台注册账户获取AppK ...

  4. 第三方登录(QQ登录)开发流程详解

    原文:http://www.cnblogs.com/it-cen/p/4338202.html 近排由于工作的繁忙,已经一个星期没写博文做分享了,接下来我对网站接入第三方登录----QQ登录的实现逻辑 ...

  5. (转)第三方登录(QQ登录)开发流程详解

    近排由于工作的繁忙,已经一个星期没写博文做分享了,接下来我对网站接入第三方登录----QQ登录的实现逻辑做一个详细的讲解. 对于整个流程的详细文档可以到QQ互联官网(http://wiki.conne ...

  6. .netcore 急速接入第三方登录,不看后悔

    新年新气象,趁着新年的喜庆,肝了十来天,终于发了第一版,希望大家喜欢. 如果有不喜欢看文字的童鞋,可以直接看下面的地址体验一下: https://oauthlogin.net/ 前言 此次带来得这个小 ...

  7. 分享前端Facebook及Twitter第三方登录

    最近公司要求做海外的第三方登录:目前只做了Facebook和Twitter;国内百度到的信息太少VPN FQ百度+Google了很久终于弄好了.但是做第三方登录基本上都有个特点就是引入必须的js,设置 ...

  8. QQ第三方登录

    QQ第三方登录 在Android应用程序的开发过程中,很多时候需要加入用户登录/注册模块.除了自己动手设计登录界面并实现相应功能外,现在还可以借助百度.腾讯等开发者平台提供的第三方账号登录模块.最近研 ...

  9. 开源第三方登录组件OAuthLogin2.0 解析及开源地址

    OAuthLogin2.0介绍地址: 博客地址:http://www.cnblogs.com/dazhuangtage/p/6306133.html Nuget地址:https://www.nuget ...

随机推荐

  1. md5码加密(Python)

    import hashlib import hmac m = input('输入要加密内容:') md = hashlib.md5()#生成md5 hash对象 md.update(m.encode( ...

  2. LeetCode 100.相同的树(C++)

    给定两个二叉树,编写一个函数来检验它们是否相同. 如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的. 示例 1: 输入: 1 1 / \ / \ 2 3 2 3 [1,2,3], [1 ...

  3. eclipse中修改tomcat的配置,解决全局性的get提交乱码问题

    在项目中如果页面提交方式为get的时候,中文会出现乱码. 为了解决乱码问题我们有两种办法. 第一种:在程序中加入get提交乱码的解决 String username = new String(user ...

  4. Unity自动打包工具

    转载 https://blog.csdn.net/ynnmnm/article/details/36774715 最开始有写打包工具的想法,是因为看到<啪啪三国>王伟峰分享的一张图,他们有 ...

  5. 九度oj 1002 Grading 2011年浙江大学计算机及软件工程研究生机试真题

    #include<iostream> #include<queue> #include<cstdio> #include<cstring> #inclu ...

  6. hibernate 返回自定义对象

    关键代码老是忘记 setResultTransformer(Transformers.aliasToBean(LabourResult.class)) 代码用例: public List<Lab ...

  7. 1.文本编辑器-->CKEditor+CKFinder使用与配置

    一.CKEditor介绍 官网地址:http://ckeditor.com CKEditor下载地址:http://ckeditor.com/download CKFinder(免费版本)下载地址:h ...

  8. javascript下的arguments,caller,callee,call,apply示例及理解

    (参考:http://justcoding.iteye.com/blog/589111) Arguments  该对象代表正在执行的函数和调用它的函数的参数. [function.]arguments ...

  9. WebAPI搭建(二) 让WebAPI 返回JSON格式的数据

    在RestFul风格盛行的年代,对接接口大多数人会选择使用JSON,XML和JSON的对比传送(http://blog.csdn.net/liaomin416100569/article/detail ...

  10. type=file的change事件只能执行一次的解决方案

    最近帮朋友做个项目中遇到了type=file change事件只能执行一次的问题,度娘了一下,发现提供了各种解决方案,所以决定记录一下我的思考方向和最终解决方式. 起初帮朋友做个项目,项目中遇到上传文 ...