Thinkphp集成抖音SDK的实现方法


Posted in PHP onApril 28, 2020

由于抖音官方SDK相关教程太少, 所以本着 前人种树后人乘凉 的精神,写下本篇博客

第一步:下载抖音官方SDK

下载地址:抖音SDK官方下载
选择 Php下载地址 进行下载即可

Thinkphp集成抖音SDK的实现方法

第二步:将SDK导入

1.解压下载的压缩文件

2.在thinkphp项目的根目录(与application目录同级)下的extend目录下新建Douyin目录,再在Douyin目录里新建Open目录

Thinkphp集成抖音SDK的实现方法

3.将解压出来的php-sdk/douyin_open/lib目录里面的所有文件和文件夹全部复制到刚才新建的Douyin\Open目录下

Thinkphp集成抖音SDK的实现方法

复制完成后目录结构如下

Thinkphp集成抖音SDK的实现方法

第三步:安装guzzlehttp依赖

因为抖音的SDK基本都是基于guzzlehttp发送的请求,所以需要安装依赖

我这里使用Composer进行安装,如你还未安装Composer ,请先安装

  • 1.执行命令 composer require guzzlehttp/guzzle:~6.0
  • 2.安装完成后即可调用接口

第四步:接口调用

接口调用可参考下载的SDK内置的php-sdk\douyin_open\test\Api,里面有大部分API调用方法,可参考调用

我这里只演示授权并获取用户信息

<?php
/**
 * Created by PhpStorm.
 * User: bigniu
 * Date: 2020-04-25
 * Time: 21:46:42
 */

namespace app\api\controller\v1;


use Douyin\Open\Api\DefaultApi;
use Douyin\Open\Api\UserInfoApi;
use Exception;
use GuzzleHttp\Client;
use think\Controller;

class Douyin extends Controller
{
  public function auth($code='')
  {
    //创建默认API的实例,verify=false不做ssl验证,否则可能报错,根据实际情况而定
    $apiInstance = new DefaultApi(new Client(['verify' => false]));
    //填写自己的client_key
    $client_key = "xxx";
    //填写自己的client_secret
    $client_secret = "xxx";
    $grant_type = 'authorization_code';//根据官方文档填写
    try {
      //调用获取AccessToken的接口
      $result = $apiInstance->oauthAccessTokenGet($client_key, $client_secret, $code, $grant_type);
    } catch (Exception $e) {
      return error("登录失败");
    }
    //判断返回的数据是否为空
    if (!$result) {
      return error("登录失败");
    }
    //判断返回的Message是否为error
    if ($result->getMessage() == 'error') {
      return error("登录失败");
    }
    //获取返回数据
    $data=$result->getData();
    //获取openid和access_toekn
    $openid = $data->getOpenId();
    $access_token = $data->getAccessToken();
    //创建用户信息API
    $userApi = new UserInfoApi(new Client(['verify' => false]));
    //获取用户信息
    $userInfo = $userApi->oauthUserinfoGetWithHttpInfo($access_token,$openid);
    dump($userInfo);

  }
}

常见问题整理

一、[0] cURL error 60: SSL certificate problem: unable to get local issuer certificate (see https://curl.haxx.se/libcurl/c/libcurl-errors.html) 错误

问题原因

该错误是由于 SSL证书 验证的原因

解决方案1

只需要把$apiInstance = new DefaultApi(new Client());改为$apiInstance = new DefaultApi(new Client(['verify'=>false])); 即可,主要是修改new Client()这里,其他API同样

解决方案2: 下载一个ca-bundle.crt ,放到对应的目录,在php.ini文件中配置下路径
https://github.com/bagder/ca-bundle/blob/e9175fec5d0c4d42de24ed6d84a06d504d5e5a09/ca-bundle.crt
在php.ini的末尾加入 ,

curl.cainfo="真实路径/ca-bundle.crt"

重启web服务器

二、提示配置无效

调用授权登录接口https://open.douyin.com/platform/oauth/connect?client_key=xxx&response_type=code&scope=user_info&redirect_uri=redirect_uri&state=1提示授权失败或配置失效

Thinkphp集成抖音SDK的实现方法

问题原因

申请的应用为移动应用,实际调用为网页应用web扫码,网页应用在申请的时候有个授权域回调的配置,就是填写回调域名的

Thinkphp集成抖音SDK的实现方法

解决方案

重新申请网页应用,需要填写这个回调地址

Thinkphp集成抖音SDK的实现方法

三、获取用户信息报Invalid value for ‘e_account_role', must be one of ‘EAccountM', ‘EAccountS', ‘EAccountK'

调用UserInfoApioauthUserinfoGetWithHttpInfo接口出现该错误

问题原因

由于返回用户信息里的e_account_role字段为null所导致,可通过修改API解决,这个错误一般为非正常调用API所导致,如:使用移动应用的client_key强制授权网页应用导致

解决方案

由于返回用户信息里的e_account_role字段为null所导致,可通过修改API解决
根据TP的错误提示我们可以发下报错发生在Douyin\Open\Model\OauthUserinfoResponseData.php line 564
错误发生在第564行代码

将563 - 570行注释掉即可获取正常用户信息

修改前:

Thinkphp集成抖音SDK的实现方法

修改后:

Thinkphp集成抖音SDK的实现方法

到此这篇关于Thinkphp集成抖音SDK的实现方法的文章就介绍到这了,更多相关Thinkphp集成抖音SDK内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

PHP 相关文章推荐
第六节 访问属性和方法 [6]
Oct 09 PHP
什么是MVC,好东西啊
May 03 PHP
支持中文的php加密解密类代码
Nov 27 PHP
PHP面向对象学习笔记之一 基础概念
Oct 06 PHP
PHP Global变量定义当前页面的全局变量实现探讨
Jun 05 PHP
PHP error_log()将错误信息写入一个文件(定义和用法)
Oct 25 PHP
ThinkPHP实现支付宝接口功能实例
Dec 02 PHP
PHP输入流php://input实例讲解
Dec 22 PHP
php自定义函数实现二维数组按指定key排序的方法
Sep 29 PHP
通过修改Laravel Auth使用salt和password进行认证用户详解
Aug 17 PHP
Yii框架的布局文件实例分析
Sep 04 PHP
laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作示例
Feb 18 PHP
PHP扩展类型及安装方式解析
Apr 27 #PHP
PHP如何开启Opcache功能提升程序处理效率
Apr 27 #PHP
Thinkphp 框架基础之入口文件功能、定义与用法分析
Apr 27 #PHP
Thinkphp 框架基础之源码获取、环境要求与目录结构分析
Apr 27 #PHP
Thinkphp 框架扩展之驱动扩展实例分析
Apr 27 #PHP
Thinkphp 框架扩展之应用模式实现方法分析
Apr 27 #PHP
php让json_encode不自动转义斜杠“/”的方法
Apr 27 #PHP
You might like
星际玩家的三大定律
2020/03/04 星际争霸
PHP操作xml代码
2010/06/17 PHP
PHP上传文件时自动分配路径的方法
2015/01/09 PHP
php使用GD2绘制几何图形示例
2017/02/15 PHP
PHP开发实现快递查询功能详解
2019/04/08 PHP
javascript 获取元素位置的快速方法 getBoundingClientRect()
2009/11/26 Javascript
SWFObject 2.1以上版本语法介绍
2010/07/10 Javascript
JavaScript中把数字转换为字符串的程序代码
2013/06/19 Javascript
JQuery标签页效果实例详解
2015/12/24 Javascript
js密码强度实时检测代码
2016/03/02 Javascript
一种Javascript解释ajax返回的json的好方法(推荐)
2016/06/02 Javascript
JavaScript中无法通过div.style.left获取值的解决方法
2017/02/19 Javascript
使用原生js+canvas实现模拟心电图的实例
2017/09/20 Javascript
vue-cli项目根据线上环境分别打出测试包和生产包
2018/05/23 Javascript
layui的面包屑或者表单不显示的解决方法
2019/09/05 Javascript
基于vue和websocket的多人在线聊天室
2020/02/01 Javascript
[55:48]VGJ.S vs TNC Supermajor 败者组 BO3 第二场 6.6
2018/06/07 DOTA
基于Python实现文件大小输出
2016/01/11 Python
python生成词云的实现方法(推荐)
2017/06/13 Python
基于Python实现的ID3决策树功能示例
2018/01/02 Python
基于Pandas读取csv文件Error的总结
2018/06/15 Python
python实现在图片上画特定大小角度矩形框
2018/10/24 Python
python实现的MySQL增删改查操作实例小结
2018/12/19 Python
浅谈python3发送post请求参数为空的情况
2018/12/28 Python
解决Tensorflow 使用时cpu编译不支持警告的问题
2020/02/03 Python
Python如何爬取qq音乐歌词到本地
2020/06/01 Python
Python urllib2运行过程原理解析
2020/06/04 Python
python3字符串输出常见面试题总结
2020/12/01 Python
什么是典型的软件三层结构?软件设计为什么要分层?软件分层有什么好处?
2012/03/14 面试题
平面设计岗位职责
2013/12/14 职场文书
小学中秋节活动方案
2014/02/06 职场文书
《天游峰的扫路人》教学反思
2014/04/25 职场文书
群众路线查摆问题及整改措施
2014/10/10 职场文书
先进教师个人主要事迹材料
2015/11/03 职场文书
演讲稿:​快乐,从不抱怨开始!
2019/04/02 职场文书
Android Studio实现简易进制转换计算器
2022/05/20 Java/Android