了解Thinkphp集成抖音SDK的實現方法

了解Thinkphp集成抖音SDK的實現方法

由于抖音官方SDK相關教程太少, 所以本著 前人種樹后人乘涼 的精神,寫下本篇博客

第一步:下載抖音官方SDK

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

了解Thinkphp集成抖音SDK的實現方法

相關學習推薦:thinkphp

第二步:將SDK導入

立即學習PHP免費學習筆記(深入)”;

1.解壓下載的壓縮文件

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

了解Thinkphp集成抖音SDK的實現方法

3.將解壓出來的php-sdk/douyin_open/lib目錄里面的所有文件和文件夾全部復制到剛才新建的DouyinOpen目錄下

了解Thinkphp集成抖音SDK的實現方法

復制完成后目錄結構如下

了解Thinkphp集成抖音SDK的實現方法

第三步:安裝guzzlehttp依賴

因為抖音的SDK基本都是基于guzzlehttp發送的請求,所以需要安裝依賴

我這里使用Composer進行安裝,如你還未安裝Composer ,請先安裝

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

第四步:接口調用

接口調用可參考下載的SDK內置的php-sdkdouyin_opentestApi,里面有大部分API調用方法,可參考調用

我這里只演示授權并獲取用戶信息

<?php /**  * Created by PhpStorm.  * User: bigniu  * Date: 2020-04-25  * Time: 21:46:42  */  namespace appapicontrollerv1;   use DouyinOpenApiDefaultApi; use DouyinOpenApiUserInfoApi; use Exception; use GuzzleHttpClient; use thinkController;  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?=?'authorization_code';//根據官方文檔填寫 ????try?{ ??????//調用獲取AccessToken的接口 ??????$result?=?$apiInstance-&gt;oauthAccessTokenGet($client_key,?$client_secret,?$code,?$grant_type); ????}?catch?(Exception?$e)?{ ??????return?error("登錄失敗"); ????} ????//判斷返回的數據是否為空 ????if?(!$result)?{ ??????return?error("登錄失敗"); ????} ????//判斷返回的Message是否為error ????if?($result-&gt;getMessage()?==?'error')?{ ??????return?error("登錄失敗"); ????} ????//獲取返回數據 ????$data=$result-&gt;getData(); ????//獲取openid和access_toekn ????$openid?=?$data-&gt;getOpenId(); ????$access_token?=?$data-&gt;getAccessToken(); ????//創建用戶信息API ????$userApi?=?new?UserInfoApi(new?Client(['verify'?=&gt;?false])); ????//獲取用戶信息 ????$userInfo?=?$userApi-&gt;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’

調用UserInfoApi的oauthUserinfoGetWithHttpInfo接口出現該錯誤

問題原因

由于返回用戶信息里的e_account_role字段為null所導致,可通過修改API解決,這個錯誤一般為非正常調用API所導致,如:使用移動應用的client_key強制授權網頁應用導致

解決方案

由于返回用戶信息里的e_account_role字段為null所導致,可通過修改API解決
根據TP的錯誤提示我們可以發下報錯發生在DouyinOpenModelOauthUserinfoResponseData.php line 564
錯誤發生在第564行代碼

將563 – 570行注釋掉即可獲取正常用戶信息

修改前:

了解Thinkphp集成抖音SDK的實現方法

修改后:

了解Thinkphp集成抖音SDK的實現方法

相關學習推薦:編程視頻

? 版權聲明
THE END
喜歡就支持一下吧
點贊5 分享