Maison > Article > développement back-end > Tutoriel détaillé sur la requête d'envoi de php curl
Si vous souhaitez en savoir plus sur php, vous pouvez cliquer sur : Tutoriel php
cURL peut utiliser la syntaxe URL pour simuler un navigateur afin de transmettre des données. Parce qu'il simule un navigateur, il prend également en charge plusieurs protocoles, FTP, FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT, FILE et LDAP. peut être bien pris en charge, notamment : l'authentification HTTPS, la méthode HTTP POST, la méthode HTTP PUT, le téléchargement FTP, l'authentification keyberos, le téléchargement HTTP, le serveur proxy, les cookies, l'authentification par nom d'utilisateur/mot de passe, les points d'arrêt de téléchargement de fichiers Reprendre le téléchargement, reprendre le téléchargement de fichiers aux points d'arrêt, Pipeline de serveur proxy http, et prend même en charge IPv6, le serveur proxy scoket5, télécharge des fichiers sur le serveur FTP via le serveur proxy http, etc.
L'utilisation de la bibliothèque cURL de PHP permet d'explorer facilement et efficacement les pages Web. Il vous suffit d'exécuter un script, puis d'analyser les pages Web que vous avez explorées, et vous pourrez ensuite obtenir les données souhaitées par programme. Que vous souhaitiez récupérer des données partielles d'un lien, prendre un fichier XML et l'importer dans une base de données, ou même simplement récupérer le contenu d'une page Web, cURL est une puissante bibliothèque PHP.
1. Étapes de base pour établir une requête CURL en PHP
① : Initialisation
curl_init()
② : Définir les propriétés
curl_setopt()
Il existe une longue liste de paramètres cURL à définir, qui peuvent spécifier divers détails de la demande d'URL.
③ : Exécuter et obtenir le résultat
curl_exec()
④ : Relâcher la poignée
curl_close()
2. Exemple :
php curl envoie une requête d'obtention :
//初始化 $curl = curl_init(); //设置抓取的url curl_setopt($curl, CURLOPT_URL, 'http://www.baidu.com'); //设置头文件的信息作为数据流输出 curl_setopt($curl, CURLOPT_HEADER, 1); //设置获取的信息以文件流的形式返回,而不是直接输出。 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); //执行命令 $data = curl_exec($curl); echo curl_getinfo($curl,CURLINFO_HTTP_CODE); //输出请求状态码 //关闭URL请求 curl_close($curl); //显示获得的数据 print_r($data);
php curl envoie une demande de publication :
//初始化 $curl = curl_init(); //设置抓取的url curl_setopt($curl, CURLOPT_URL, 'http://localhost/test/test.php'); //设置头文件的信息作为数据流输出 curl_setopt($curl, CURLOPT_HEADER, 1); //设置获取的信息以文件流的形式返回,而不是直接输出。 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); //设置post方式提交 curl_setopt($curl, CURLOPT_POST, 1); //设置post数据 $post_data = array( "title" => "1290800466", "content" => "3424243243" ); //post提交的数据 curl_setopt($curl, CURLOPT_POSTFIELDS, $post_data); //执行命令 $data = curl_exec($curl); //关闭URL请求 curl_close($curl); //显示获得的数据 print_r($data);
test.php:
<?php $title = $_REQUEST['title']; $content = $_REQUEST['content']; error_log($title."\n",3,'error.log'); error_log($content."\n",3,'error.log'); echo 'ok';
3. Fonction PHP cURL :
Ce qui suit contient une liste des fonctions PHP cURL :
Fonction | Description |
---|---|
curl_close() | Ferme une session cURL. |
curl_copy_handle() | Copiez un handle cURL et toutes ses options. |
curl_errno() | Renvoie le dernier numéro d'erreur. |
curl_error() | Renvoie une chaîne qui protège la dernière erreur de la session en cours. |
curl_escape() | Renvoie la chaîne d'échappement, l'URL codant la chaîne donnée. |
curl_exec() | Exécuter une session cURL. |
curl_file_create() | Créez un objet CURLFile. |
curl_getinfo() | Obtenir des informations sur un handle de ressource de connexion cURL. |
curl_init() | Initialiser une session cURL. |
curl_multi_add_handle() | Ajoutez des poignées de curl individuelles à une session par lots de curl. |
curl_multi_close() | Ferme un groupe de handles cURL. |
curl_multi_exec() | Exécuter une sous-connexion du handle cURL actuel. |
curl_multi_getcontent() | Si CURLOPT_RETURNTRANSFER est défini, renvoie le flux de texte de la sortie obtenue. |
curl_multi_info_read() | Obtenir les informations de transmission pertinentes du cURL actuellement analysé. |
curl_multi_init() | Renvoie un nouveau handle de lot cURL. |
curl_multi_remove_handle() | Supprimer une ressource de handle dans la ressource de handle du lot curl. |
curl_multi_select() | Attendez toutes les connexions actives dans le lot cURL. |
curl_multi_setopt() | Définit une option de transfert cURL par lots. |
curl_multi_strerror() | Renvoie une chaîne de texte décrivant le code d'erreur. |
curl_pause() | Pause et reprenez la connexion. |
curl_reset() | Réinitialise toutes les options du handle de session de libcurl. |
curl_setopt_array() | Définissez les options en masse pour les sessions de transfert cURL. |
curl_setopt() | Définit une option de transfert cURL. |
curl_share_close() | Fermez le handle de partage cURL. |
curl_share_init() | Initialisez le handle de partage cURL. |
curl_share_setopt() | Définit les options de transfert cURL pour un handle partagé. |
curl_strerror() | Renvoie une description de chaîne du code d'erreur. |
curl_unescape() | Décoder la chaîne codée en URL. |
curl_version() | Obtenir des informations sur la version de cURL. |
Renvoie VRAI en cas de succès, ou FAUX en cas d'échec.
Quelques codes d'état
1xx : Demande reçue, poursuivre le traitement
2xx : Opération reçue avec succès, analyse, Accepter
3xx : La finalisation de cette requête doit nécessiter un traitement ultérieur.
4xx : La requête contient une syntaxe incorrecte ou ne peut pas être complétée.
5xx : Le serveur n'a pas réussi à exécuter une requête entièrement valide.
100 - Le client doit continuer à faire des requêtes
101 - Le client demande au serveur de convertir la version du protocole HTTP en fonction de la requête
200 - La transaction est réussie
201 - Invite à connaître l'URL du nouveau fichier
202 - accepté et traité, mais le traitement n'est pas terminé
203 - les informations de retour sont incertaines ou incomplètes
204 - requête reçue, mais les informations de retour sont vides
205 - Le serveur a terminé la requête, l'agent utilisateur doit réinitialiser les fichiers en cours de navigation
206 - Le serveur a complété certaines Requêtes GET des utilisateurs
300 - La ressource demandée est disponible à plusieurs endroits
301 - Supprimer les données de la demande
302 - Les données de la demande ont été trouvées à d'autres adresses
303— —Il est recommandé aux clients de visiter d'autres URL ou méthodes d'accès
304 - Le client a exécuté GET, mais le fichier n'a pas changé
305 - La ressource demandée doit être obtenu à partir de l'adresse indiquée par le serveur
306 - Code utilisé dans la version précédente de HTTP, n'est plus utilisé dans la version actuelle
307 - Déclaration selon laquelle la ressource demandée est temporairement supprimée
400 - Requête incorrecte, telle qu'une erreur de syntaxe
401 - Échec de l'autorisation de la demande
402 - Conserver la réponse d'en-tête ChargeTo valide
403 - Demande non autorisée
404 - Aucun fichier, requête ou URL trouvé
405 - La méthode définie par l'utilisateur dans le champ Request-Line n'est pas autorisée
406 - Selon le glisser Accepter envoyée par l'utilisateur, la ressource demandée est inaccessible
407 - Semblable au 401, l'utilisateur doit d'abord obtenir une autorisation sur le serveur proxy
408 - Le client n'a pas complété la demande dans le délai spécifié par l'utilisateur
409 - Pour l'état actuel de la ressource, la demande ne peut pas être complétée
410 - Cette ressource n'existe plus sur le serveur et il n'y a pas d'autre adresse de référence
411 - Le serveur rejette la demande d'attribut Content-Length définie par l'utilisateur
412 - Un ou plusieurs champs d'en-tête de demande sont incorrects dans la demande actuelle
413 - La ressource demandée est plus grande que la taille autorisée par le serveur
414 - L'URL de la ressource demandée est plus longue que celle du serveur Longueur autorisée
415 - La ressource demandée ne prend pas en charge le format de l'élément de la requête
416 - La requête contient le champ d'en-tête de requête Range, et il n'y a aucune valeur d'indication de plage dans la plage de ressources de requête actuelle, demandant
Elle ne contient pas non plus le champ d'en-tête de requête If-Range
417 - Le le serveur ne répond pas aux attentes spécifiées dans le champ d'en-tête Expect de la requête. S'il s'agit d'un serveur proxy, il se peut que le serveur de niveau suivant ne puisse pas satisfaire la requête
500 - Le serveur a généré une erreur interne
501 - Le serveur ne prend pas en charge la fonction demandée
502 - Le serveur est temporairement indisponible, parfois pour éviter une surcharge du système
503——Le serveur est surchargé ou suspendu pour maintenance
504——La passerelle est surchargée, le serveur utilise une autre porte ou un autre service pour répondre à l'utilisateur et la valeur du paramètre de temps d'attente est plus longue.
505——Serveur La version HTTP spécifiée dans l'en-tête de la requête n'est pas pris en charge ou a refusé d'être pris en charge
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!