由於抖音官方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
,請先安裝
composer require guzzlehttp/guzzle:~6.0
第四步:介面呼叫
介面呼叫可參考下載的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'
呼叫UserInfoApi
的oauthUserinfoGetWithHttpInfo
介面出現該錯誤
問題原因
由於返回使用者資訊裡的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中文網其它相關文章!