首頁 > php框架 > ThinkPHP > 主體

了解Thinkphp整合抖音SDK的實作方法

coldplay.xixi
發布: 2020-08-14 16:48:20
轉載
5065 人瀏覽過

<img src="https://img.php.cn/upload/article/202008/14/2020081416430198815.jpg" alt="了解Thinkphp整合抖音SDK的實作方法" >

由於抖音官方SDK相關教學太少, 所以本著前人種樹後人乘涼的精神,寫下本篇部落格

第一步:下載抖音官方SDK

#下載位址:抖音SDK官方下載
選擇 Php下載位址 進行下載即可

#相關學習推薦:thinkphp

第二步:將SDK匯入

1.解壓縮下載的壓縮檔案

2.在thinkphp專案的根目錄(與application目錄同級)下的extend目錄下新建Douyin目錄,再在Douyin目錄中新建Open目錄

3.將解壓縮出來的php-sdk/douyin_open/lib目錄裡面的所有檔案和資料夾全部複製到剛才新建的Douyin\Open目錄下

複製完成後目錄結構如下

第三步:安裝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=&#39;&#39;)
  {
    //创建默认API的实例,verify=false不做ssl验证,否则可能报错,根据实际情况而定
    $apiInstance = new DefaultApi(new Client([&#39;verify&#39; => false]));
    //填写自己的client_key
    $client_key = "xxx";
    //填写自己的client_secret
    $client_secret = "xxx";
    $grant_type = &#39;authorization_code&#39;;//根据官方文档填写
    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() == &#39;error&#39;) {
      return error("登录失败");
    }
    //获取返回数据
    $data=$result->getData();
    //获取openid和access_toekn
    $openid = $data->getOpenId();
    $access_token = $data->getAccessToken();
    //创建用户信息API
    $userApi = new UserInfoApi(new Client([&#39;verify&#39; => 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/e9175fec5d0c4d42de24ed6d84a06d504d5e5a0c4d42de24ed6d84a06d504d5e. 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提示授權失敗或配置失效

問題原因

申請的應用程式為行動應用程式,實際呼叫為網頁應用程式web掃碼,網頁應用程式在申請的時候有授權網域回調的配置,就是填寫回呼網域的

#解決方案

重新申請網頁應用,需要填寫這個回呼位址

三、取得使用者資訊封包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的實作方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:jb51.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板