Maison >cadre php >PensezPHP >Comprendre comment Thinkphp intègre le SDK Douyin

Comprendre comment Thinkphp intègre le SDK Douyin

coldplay.xixi
coldplay.xixiavant
2020-08-14 16:44:155142parcourir

<img src="https://img.php.cn/upload/article/202008/14/2020081416430198815.jpg" alt="Comprendre comment Thinkphp intègre le SDK Douyin" >

由于抖音官方SDK相关教程太少, 所以本着 前人种树后人乘凉 的精神,写下本篇博客

Étape 1 : Téléchargez le SDK officiel de Douyin

Adresse de téléchargement : Douyin Téléchargement officiel du SDK
Sélectionnez Php下载地址 pour télécharger

Recommandations d'apprentissage associées : thinkphp

Étape 2 : Importez le SDK

1. Décompressez le fichier compressé téléchargé

2. Créez un nouveau extend sous le répertoire Douyin sous le répertoire racine du projet thinkphp (au même niveau que le répertoire de l'application), puis créez un nouveau répertoire Douyin Open

répertoire >3. Copiez tous les fichiers et dossiers du répertoire php-sdk/douyin_open/lib décompressé dans le répertoire

nouvellement crééDouyinOpen

Après la copie, la structure des répertoires est la suivante


Étape 3 : Installer la dépendance guzzlehttp

Parce que le SDK de Douyin est essentiellement basé sur la requête envoyée par

, vous devez installer la dépendance guzzlehttp

J'utilise

pour l'installer ici Si vous ne l'avez pas encore installé. , Composer Veuillez d'abord installer Composer

    1. Exécutez la commande
  • composer require guzzlehttp/guzzle:~6.0
  • 2. Une fois l'installation terminée, vous pouvez appeler l'interface
  • <.>

Chapitre quatre étapes : Appel d'interface L'appel d'interface peut faire référence au

intégré du SDK téléchargé, qui contient la plupart des appels d'API méthodes. Vous pouvez vous référer à l'appel

php-sdkdouyin_opentestApi. Je ne l'ai que ici Démontrer l'autorisation et obtenir des informations sur l'utilisateur

Composition des questions fréquemment posées

. 1. [0] Erreur cURL 60 : problème de certificat SSL : impossible d'obtenir le certificat de l'émetteur local (voir https://curl.haxx.se/libcurl/c/libcurl-errors.html) Erreur

Cause du problème

Cette erreur est due aux raisons de la vérification du certificat SSL

Solution 1

 :

Remplacez simplement par

, modifiez principalement new Client() ici, les autres API sont les mêmes

$apiInstance = new DefaultApi(new Client());Solution 2 : Téléchargez un ca-bundle.crt, placez-le dans le répertoire correspondant et configurez le chemin dans le fichier php.ini$apiInstance = new DefaultApi(new Client(['verify'=>false]));https://github.com/bagder/ca -bundle/blob/e9175fec5d0c4d42de24ed6d84a06d504d5e5a09/ca-bundle.crt

Ajouter à la fin du php.ini,

<?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=&#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 = &#39;authorization_code&#39;;//根据官方文档填写
    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() == &#39;error&#39;) {
      return error("登录失败");
    }
    //获取返回数据
    $data=$result->getData();
    //获取openid和access_toekn
    $openid = $data->getOpenId();
    $access_token = $data->getAccessToken();
    //创建用户信息API
    $userApi = new UserInfoApi(new Client([&#39;verify&#39; => false]));
    //获取用户信息
    $userInfo = $userApi->oauthUserinfoGetWithHttpInfo($access_token,$openid);
    dump($userInfo);

  }
}

Redémarrer le serveur Web

2. Demander que la configuration n'est pas valide

L'appel de l'interface de connexion d'autorisation

provoque un échec d'autorisation ou une configuration invalide

https://open.douyin.com/platform/oauth/connect?client_key=xxx&response_type=code&scope=user_info&redirect_uri=redirect_uri&state=1

Cause du problème

L'application demandée est , L'appel réel est

analyse du code Web L'application Web dispose d'un rappel de domaine autorisé. configuration lors de la candidature, qui consiste à renseigner le nom de domaine de rappel

移动应用网页应用

Solution

Réappliquer pour une candidature web, vous devez remplir cette adresse de rappel


3. Obtenir les informations sur l'utilisateur et signaler une valeur invalide pour 'e_account_role', doit être l'une des 'EAccountM', 'EAccountS'. , 'EAccountK'

Cette erreur se produit lors de l'appel de l'interface

de

UserInfoApioauthUserinfoGetWithHttpInfoCause du problème

Elle est causée par le champ dans les informations utilisateur renvoyées est nul, ce qui peut être résolu en modifiant l'API. Cette erreur est généralement causée par des appels d'API anormaux, comme l'utilisation de la clé_client de l'application mobile pour forcer l'autorisation de l'application Web.

e_account_roleSolution

Étant donné que le champ e_account_role dans les informations utilisateur renvoyées est nul, il peut être résolu en modifiant l'API
Selon l'invite d'erreur de TP, nous pouvons envoyer le rapport d'erreur dans DouyinOpenModelOauthUserinfoResponseData.php line 564
. L'erreur s'est produite dans 第564行代码

Commentez les lignes 563 à 570 pour obtenir des informations utilisateur normales

修改前:

修改后:

Recommandations d'apprentissage associées : Vidéo de programmation

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer