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 相关文章推荐
PHP与MySQL开发中页面乱码的产生与解决
Mar 27 PHP
PHP MYSQL乱码问题,使用SET NAMES utf8校正
Nov 30 PHP
PHP在网页中动态生成PDF文件详细教程
Jul 05 PHP
PHP面向对象精要总结
Nov 07 PHP
Yii的CDbCriteria查询条件用法实例
Dec 04 PHP
php如何执行非缓冲查询API
Jul 22 PHP
PHP针对中英文混合字符串长度判断及截取方法示例
Mar 31 PHP
PHP实现的策略模式简单示例
Aug 25 PHP
php nginx 实时输出的简单实现方法
Jan 21 PHP
Yii2框架数据验证操作实例详解
May 02 PHP
php 与 nginx 的处理方式及nginx与php-fpm通信的两种方式
Sep 28 PHP
详解php中生成标准uuid(guid)的方法
Apr 28 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
fleaphp常用方法分页之Pager使用方法
2011/04/23 PHP
php设计模式 State (状态模式)
2011/06/26 PHP
如何利用预加载优化Laravel Model查询详解
2017/08/11 PHP
laravel5.4利用163邮箱发送邮件的步骤详解
2017/09/22 PHP
PHP大文件切割上传并带进度条功能示例
2019/07/01 PHP
JQuery操作三大控件(下拉,单选,复选)的方法
2013/08/06 Javascript
js 操作符汇总
2014/11/08 Javascript
jQuery中:nth-child选择器用法实例
2014/12/31 Javascript
jQuery插件animateSlide制作多点滑动幻灯片
2015/06/11 Javascript
使用JQuery实现的分页插件分享
2015/11/05 Javascript
利用Javascript仿Excel的数据透视分析功能
2016/09/07 Javascript
JS验证字符串功能
2017/02/22 Javascript
浅谈JS中的常用选择器及属性、方法的调用
2017/07/28 Javascript
React Native模块之Permissions权限申请的实例相机
2017/09/28 Javascript
webpack 单独打包指定JS文件的方法
2018/02/22 Javascript
轻量级JS Cookie插件js-cookie的使用方法
2018/03/22 Javascript
详解原生JS回到顶部
2019/03/25 Javascript
什么时候不能在 Node.js 中使用 Lock Files
2019/06/24 Javascript
深入理解令牌认证机制(token)
2019/08/22 Javascript
浅谈JavaScript中this的指向问题
2020/07/28 Javascript
javascript实现移动端上传图片功能
2020/08/18 Javascript
antd-日历组件,前后禁止选择,只能选中间一部分的实例
2020/10/29 Javascript
Swift中的协议(protocol)学习教程
2016/07/08 Python
在django中,关于session的通用设置方法
2019/08/06 Python
基于Django signals 信号作用及用法详解
2020/03/28 Python
Python-jenkins模块获取jobs的执行状态操作
2020/05/12 Python
Python的历史与优缺点整理
2020/05/26 Python
Python3读取和写入excel表格数据的示例代码
2020/06/09 Python
HTML5 canvas基本绘图之填充样式实现
2016/06/27 HTML / CSS
.net面试题
2015/12/22 面试题
党员创先争优活动总结
2014/05/04 职场文书
物流专业专科生职业生涯规划书
2014/09/14 职场文书
护士求职简历自我评价
2015/03/10 职场文书
英语版自我评价,35句话轻松搞定
2019/10/08 职场文书
六年级作文之自救
2019/12/19 职场文书
Java服务调用RestTemplate与HttpClient的使用详解
2022/06/21 Java/Android