由于抖音官方SDK相關(guān)教程太少, 所以本著 前人種樹后人乘涼 的精神,寫下本篇博客
第一步:下載抖音官方SDK
下載地址:抖音SDK官方下載
選擇 Php下載地址
進(jìn)行下載即可
第二步:將SDK導(dǎo)入
1.解壓下載的壓縮文件
2.在thinkphp項目的根目錄(與application目錄同級)下的extend
目錄下新建Douyin
目錄,再在Douyin
目錄里新建Open
目錄
3.將解壓出來的php-sdk/douyin_open/lib目錄里面的所有文件和文件夾全部復(fù)制到剛才新建的Douyin\Open
目錄下
復(fù)制完成后目錄結(jié)構(gòu)如下
第三步:安裝guzzlehttp依賴
因為抖音的SDK基本都是基于guzzlehttp
發(fā)送的請求,所以需要安裝依賴
我這里使用Composer
進(jìn)行安裝,如你還未安裝Composer
,請先安裝
- 1.執(zhí)行命令
composer require guzzlehttp/guzzle:~6.0
- 2.安裝完成后即可調(diào)用接口
第四步:接口調(diào)用
接口調(diào)用可參考下載的SDK內(nèi)置的php-sdk\douyin_open\test\Api
,里面有大部分API調(diào)用方法,可參考調(diào)用
我這里只演示授權(quán)并獲取用戶信息
?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='')
{
//創(chuàng)建默認(rèn)API的實例,verify=false不做ssl驗證,否則可能報錯,根據(jù)實際情況而定
$apiInstance = new DefaultApi(new Client(['verify' => false]));
//填寫自己的client_key
$client_key = "xxx";
//填寫自己的client_secret
$client_secret = "xxx";
$grant_type = 'authorization_code';//根據(jù)官方文檔填寫
try {
//調(diào)用獲取AccessToken的接口
$result = $apiInstance->oauthAccessTokenGet($client_key, $client_secret, $code, $grant_type);
} catch (Exception $e) {
return error("登錄失敗");
}
//判斷返回的數(shù)據(jù)是否為空
if (!$result) {
return error("登錄失敗");
}
//判斷返回的Message是否為error
if ($result->getMessage() == 'error') {
return error("登錄失敗");
}
//獲取返回數(shù)據(jù)
$data=$result->getData();
//獲取openid和access_toekn
$openid = $data->getOpenId();
$access_token = $data->getAccessToken();
//創(chuàng)建用戶信息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 ,放到對應(yīng)的目錄,在php.ini文件中配置下路徑
https://github.com/bagder/ca-bundle/blob/e9175fec5d0c4d42de24ed6d84a06d504d5e5a09/ca-bundle.crt
在php.ini的末尾加入 ,
curl.cainfo="真實路徑/ca-bundle.crt"
重啟web服務(wù)器
二、提示配置無效
調(diào)用授權(quán)登錄接口https://open.douyin.com/platform/oauth/connect?client_key=xxxresponse_type=codescope=user_inforedirect_uri=redirect_uristate=1
提示授權(quán)失敗或配置失效
問題原因
申請的應(yīng)用為移動應(yīng)用
,實際調(diào)用為網(wǎng)頁應(yīng)用
web掃碼,網(wǎng)頁應(yīng)用在申請的時候有個授權(quán)域回調(diào)的配置,就是填寫回調(diào)域名的
解決方案
重新申請網(wǎng)頁應(yīng)用,需要填寫這個回調(diào)地址
三、獲取用戶信息報Invalid value for ‘e_account_role', must be one of ‘EAccountM', ‘EAccountS', ‘EAccountK'
調(diào)用UserInfoApi
的oauthUserinfoGetWithHttpInfo
接口出現(xiàn)該錯誤
問題原因
由于返回用戶信息里的e_account_role
字段為null所導(dǎo)致,可通過修改API解決,這個錯誤一般為非正常調(diào)用API所導(dǎo)致,如:使用移動應(yīng)用的client_key強制授權(quán)網(wǎng)頁應(yīng)用導(dǎo)致
解決方案
由于返回用戶信息里的e_account_role
字段為null所導(dǎo)致,可通過修改API解決
根據(jù)TP的錯誤提示我們可以發(fā)下報錯發(fā)生在Douyin\Open\Model\OauthUserinfoResponseData.php line 564
錯誤發(fā)生在第564行代碼
將563 - 570行注釋掉即可獲取正常用戶信息
修改前:
修改后:
到此這篇關(guān)于Thinkphp集成抖音SDK的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)Thinkphp集成抖音SDK內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 微信sdk實現(xiàn)禁止微信分享(使用原生php實現(xiàn))
- PHP如何實現(xiàn)阿里云短信sdk靈活應(yīng)用在項目中的方法
- PHP實現(xiàn)微信支付(jsapi支付)和退款(無需集成支付SDK)流程教程詳解
- thinkPHP微信分享接口JSSDK用法實例
- thinkPHP簡單導(dǎo)入和使用阿里云OSSsdk的方法
- php一個文件搞定微信jssdk配置
- PHP實現(xiàn)微信JS-SDK接口選擇相冊及拍照并上傳的方法
- 微信支付PHP SDK之微信公眾號支付代碼詳解
- 微信公眾平臺開發(fā)接口PHP SDK完整版
- PHP sdk實現(xiàn)在線打包代碼示例