Comprendre comment Thinkphp intègre le SDK Douyin
<img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/article/202008/14/2020081416430198815.jpg" class="lazy" 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

nouvellement crééDouyinOpen
É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
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'appelphp-sdkdouyin_opentestApi
. Je ne l'ai que ici Démontrer l'autorisation et obtenir des informations sur l'utilisateur
. 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
<?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); } }
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'
de
UserInfoApi
oauthUserinfoGetWithHttpInfo
Cause 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_role
Solution
É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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Pour exécuter le projet ThinkPHP, vous devez : installer Composer ; utiliser Composer pour créer le projet ; entrer dans le répertoire du projet et exécuter php bin/console serve ; visiter http://localhost:8000 pour afficher la page d'accueil.

ThinkPHP dispose de plusieurs versions conçues pour différentes versions de PHP. Les versions majeures incluent 3.2, 5.0, 5.1 et 6.0, tandis que les versions mineures sont utilisées pour corriger les bogues et fournir de nouvelles fonctionnalités. La dernière version stable est ThinkPHP 6.0.16. Lorsque vous choisissez une version, tenez compte de la version PHP, des exigences en matière de fonctionnalités et du support de la communauté. Il est recommandé d'utiliser la dernière version stable pour de meilleures performances et une meilleure assistance.

Étapes pour exécuter ThinkPHP Framework localement : Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un hôte virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

Comparaison des performances des frameworks Laravel et ThinkPHP : ThinkPHP fonctionne généralement mieux que Laravel, en se concentrant sur l'optimisation et la mise en cache. Laravel fonctionne bien, mais pour les applications complexes, ThinkPHP peut être mieux adapté.

Étapes d'installation de ThinkPHP : Préparez les environnements PHP, Composer et MySQL. Créez des projets à l'aide de Composer. Installez le framework ThinkPHP et ses dépendances. Configurez la connexion à la base de données. Générez le code de l'application. Lancez l'application et visitez http://localhost:8000.

"Suggestions de développement : comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones" Avec le développement rapide de la technologie Internet, les applications Web ont des exigences de plus en plus élevées pour gérer un grand nombre de requêtes simultanées et une logique métier complexe. Afin d'améliorer les performances du système et l'expérience utilisateur, les développeurs envisagent souvent d'utiliser des tâches asynchrones pour effectuer certaines opérations chronophages, telles que l'envoi d'e-mails, le traitement des téléchargements de fichiers, la génération de rapports, etc. Dans le domaine de PHP, le framework ThinkPHP, en tant que framework de développement populaire, offre des moyens pratiques d'implémenter des tâches asynchrones.

ThinkPHP est un framework PHP hautes performances présentant des avantages tels que le mécanisme de mise en cache, l'optimisation du code, le traitement parallèle et l'optimisation des bases de données. Les tests de performances officiels montrent qu'il peut gérer plus de 10 000 requêtes par seconde et qu'il est largement utilisé dans les sites Web à grande échelle et les systèmes d'entreprise tels que JD.com et Ctrip dans les applications réelles.

Le service RPC basé sur ThinkPHP6 et Swoole implémente la fonction de transfert de fichiers Introduction : Avec le développement d'Internet, le transfert de fichiers est devenu de plus en plus important dans notre travail quotidien. Afin d'améliorer l'efficacité et la sécurité du transfert de fichiers, cet article présentera la méthode d'implémentation spécifique de la fonction de transfert de fichiers basée sur le service RPC basé sur ThinkPHP6 et Swoole. Nous utiliserons ThinkPHP6 comme framework Web et utiliserons la fonction RPC de Swoole pour réaliser le transfert de fichiers entre serveurs. 1. Norme environnementale
