瞭解Thinkphp整合抖音SDK的實現方法

2020-08-14 18:00:13

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

第一步:下載抖音官方SDK

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

相關學習推薦:

第二步:將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='')
  {
    //建立預設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提示授權失敗或設定失效

問題原因

申請的應用爲移動應用,實際呼叫爲網頁應用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中文網其它相關文章!