Maison  >  Article  >  développement back-end  >  Tutoriel détaillé sur la requête d'envoi de php curl

Tutoriel détaillé sur la requête d'envoi de php curl

angryTom
angryTomoriginal
2019-07-31 16:33:139618parcourir

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[&#39;title&#39;];
$content = $_REQUEST[&#39;content&#39;];
error_log($title."\n",3,&#39;error.log&#39;);
error_log($content."\n",3,&#39;error.log&#39;);
echo &#39;ok&#39;;

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn