Utilisation de PHP pour développer et implémenter l'enregistrement et l'analyse des journaux d'accès de l'interface API Baidu Wenxin Yiyan
L'API Yiyan est une interface API très populaire qui peut afficher une phrase sur une page Web, ce qui est très simple et pratique. Dans le développement quotidien, nous devons souvent utiliser cette interface API pour ajouter du contenu intéressant à la page Web. Cependant, pour la journalisation et l’analyse des interfaces, nous avons parfois besoin d’implémentations personnalisées.
Cet article expliquera comment utiliser le développement PHP pour réaliser l'enregistrement et l'analyse du journal d'accès de l'interface API Baidu Wenxin Yiyan. Nous utiliserons la base de données MySQL pour stocker les logs d'accès de l'interface et les analyser selon différentes dimensions.
Tout d'abord, nous devons créer une table de base de données pour stocker le journal d'accès de l'interface. Vous pouvez créer une table nommée api_logs, contenant les champs id, api,category et create_at. Parmi eux, id est l'identifiant unique du journal, api est le chemin d'accès de l'interface, catégorie est le type renvoyé par l'API Yiyan et create_at est l'heure de création du journal.
Ce qui suit est l'instruction SQL pour créer la table api_logs :
CREATE TABLE api_logs ( id INT(11) AUTO_INCREMENT PRIMARY KEY, api VARCHAR(255) NOT NULL, category VARCHAR(255) NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
Ensuite, nous devons écrire du code PHP pour enregistrer le journal d'accès de l'API Yiyan. Nous pouvons insérer du code de journalisation après le segment de code qui accède à l'API Yiyan. L'exemple de code est le suivant :
// 获取一言API的返回结果 $result = file_get_contents('https://v1.hitokoto.cn'); // 解析返回结果 $data = json_decode($result, true); // 获取返回结果中的类型和内容 $category = $data['type']; $content = $data['hitokoto']; // 记录日志 $sql = "INSERT INTO api_logs (api, category) VALUES ('https://v1.hitokoto.cn', '$category')"; mysqli_query($conn, $sql);
Dans le code, nous utilisons d'abord la fonction file_get_contents pour obtenir le résultat de retour de l'API Yiyan. Ensuite, utilisez la fonction json_decode pour analyser le résultat renvoyé et obtenir le type et le contenu. Ensuite, nous utilisons la fonction mysqli_query de MySQLi pour exécuter l'instruction SQL insert et insérer le chemin d'accès et le type de l'interface dans la table api_logs.
Maintenant, nous avons terminé l'enregistrement du journal d'accès de l'interface API Yiyan. Ensuite, nous pouvons analyser les journaux. Voici un exemple simple pour compter le nombre d'accès à l'interface de chaque type :
// 查询每个类型的接口访问次数 $sql = "SELECT category, COUNT(*) AS count FROM api_logs GROUP BY category"; $result = mysqli_query($conn, $sql); // 输出结果 while ($row = mysqli_fetch_assoc($result)) { echo '类型:' . $row['category'] . ',访问次数:' . $row['count'] . '<br>'; }
Dans le code, nous utilisons la clause GROUP BY de SQL pour regrouper le champ de catégorie, et utilisons la fonction COUNT pour compter le nombre d'accès à l'interface de chaque type. Ensuite, les résultats de la requête sont parcourus via la fonction mysqli_fetch_assoc, et le type et le nombre d'accès sont affichés.
Grâce aux exemples de code ci-dessus, nous pouvons réaliser l'enregistrement et l'analyse du journal d'accès de l'interface API Baidu Wenxin Yiyan. Bien entendu, vous pouvez également le personnaliser et l'étendre en fonction de besoins spécifiques, comme l'ajout d'informations plus détaillées telles que l'adresse IP, la date ou la mise en œuvre d'autres fonctions d'analyse statistique.
Résumé :
Cet article présente comment utiliser PHP pour développer et implémenter l'enregistrement et l'analyse des journaux d'accès de l'interface API Baidu Wenxin Yiyan. Nous stockons les journaux via MySQL et écrivons du code PHP pour enregistrer les journaux et les analyser. J'espère que cet article pourra aider tout le monde et vous fournir quelques idées et références pour la journalisation pendant le processus de développement.
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!