您好,登錄后才能下訂單哦!
這篇文章主要介紹“如何實(shí)現(xiàn)Thinkphp集成抖音SDK”,在日常操作中,相信很多人在如何實(shí)現(xiàn)Thinkphp集成抖音SDK問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何實(shí)現(xiàn)Thinkphp集成抖音SDK”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
第一步:下載抖音官方SDK
下載地址:抖音SDK官方下載
選擇 Php下載地址
進(jìn)行下載即可
第二步:將SDK導(dǎo)入
1.解壓下載的壓縮文件
2.在thinkphp項(xiàng)目的根目錄(與application目錄同級(jí))下的extend
目錄下新建Douyin
目錄,再在Douyin
目錄里新建Open
目錄
3.將解壓出來的php-sdk/douyin_open/lib目錄里面的所有文件和文件夾全部復(fù)制到剛才新建的Douyin\Open
目錄下
復(fù)制完成后目錄結(jié)構(gòu)如下
第三步:安裝guzzlehttp依賴
因?yàn)槎兑舻腟DK基本都是基于guzzlehttp
發(fā)送的請(qǐng)求,所以需要安裝依賴
我這里使用Composer
進(jìn)行安裝,如你還未安裝Composer
,請(qǐng)先安裝
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的實(shí)例,verify=false不做ssl驗(yàn)證,否則可能報(bào)錯(cuò),根據(jù)實(shí)際情況而定 $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("登錄失敗"); } //獲取返回?cái)?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) 錯(cuò)誤
問題原因
該錯(cuò)誤是由于 SSL證書 驗(yàn)證的原因
解決方案1:
只需要把$apiInstance = new DefaultApi(new Client());
改為$apiInstance = new DefaultApi(new Client(['verify'=>false]));
即可,主要是修改new Client()這里,其他API同樣
解決方案2: 下載一個(gè)ca-bundle.crt ,放到對(duì)應(yīng)的目錄,在php.ini文件中配置下路徑
https://github.com/bagder/ca-bundle/blob/e9175fec5d0c4d42de24ed6d84a06d504d5e5a09/ca-bundle.crt
在php.ini的末尾加入 ,
curl.cainfo="真實(shí)路徑/ca-bundle.crt"
重啟web服務(wù)器
二、提示配置無效
調(diào)用授權(quán)登錄接口https://open.douyin.com/platform/oauth/connect?client_key=xxx&response_type=code&scope=user_info&redirect_uri=redirect_uri&state=1
提示授權(quán)失敗或配置失效
問題原因
申請(qǐng)的應(yīng)用為移動(dòng)應(yīng)用
,實(shí)際調(diào)用為網(wǎng)頁應(yīng)用
web掃碼,網(wǎng)頁應(yīng)用在申請(qǐng)的時(shí)候有個(gè)授權(quán)域回調(diào)的配置,就是填寫回調(diào)域名的
解決方案
重新申請(qǐng)網(wǎng)頁應(yīng)用,需要填寫這個(gè)回調(diào)地址
三、獲取用戶信息報(bào)Invalid value for ‘e_account_role', must be one of ‘EAccountM', ‘EAccountS', ‘EAccountK'
調(diào)用UserInfoApi
的oauthUserinfoGetWithHttpInfo
接口出現(xiàn)該錯(cuò)誤
問題原因
由于返回用戶信息里的e_account_role
字段為null所導(dǎo)致,可通過修改API解決,這個(gè)錯(cuò)誤一般為非正常調(diào)用API所導(dǎo)致,如:使用移動(dòng)應(yīng)用的client_key強(qiáng)制授權(quán)網(wǎng)頁應(yīng)用導(dǎo)致
解決方案
由于返回用戶信息里的e_account_role
字段為null所導(dǎo)致,可通過修改API解決
根據(jù)TP的錯(cuò)誤提示我們可以發(fā)下報(bào)錯(cuò)發(fā)生在Douyin\Open\Model\OauthUserinfoResponseData.php line 564
錯(cuò)誤發(fā)生在第564行代碼
將563 - 570行注釋掉即可獲取正常用戶信息
修改前:
修改后:
到此,關(guān)于“如何實(shí)現(xiàn)Thinkphp集成抖音SDK”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。