Maison >interface Web >js tutoriel >PHP utilise curl pour acquérir des compétences de méthode_javascript d'implémentation d'images distantes
curl nécessite la prise en charge de l'environnement PHP. Vous pouvez exécuter la fonction phpinfo() pour voir si elle est prise en charge. Généralement, vous devez supprimer le ";" devant "extension=php_curl.dll" dans php.ini et redémarrer. IIS ou APACHE.
Le code est le suivant :
/* *@通过curl方式获取指定的图片到本地 *@ 完整的图片地址 *@ 要存储的文件名 */ function getImg($url = "", $filename = "") { //去除URL连接上面可能的引号 //$url = preg_replace( '/(?:^['"]+|['"/]+$)/', '', $url ); $hander = curl_init(); $fp = fopen($filename,'wb'); curl_setopt($hander,CURLOPT_URL,$url); curl_setopt($hander,CURLOPT_FILE,$fp); curl_setopt($hander,CURLOPT_HEADER,0); curl_setopt($hander,CURLOPT_FOLLOWLOCATION,1); //curl_setopt($hander,CURLOPT_RETURNTRANSFER,false);//以数据流的方式返回数据,当为false是直接显示出来 curl_setopt($hander,CURLOPT_TIMEOUT,60); curl_exec($hander); curl_close($hander); fclose($fp); Return true; }
Lorsque vous appelez, directement getImg("/logo.jpg", "upload/image.jpg")
Code d'implémentation 2
Le code est le suivant :
<?php $url = "图片绝对地址/thumbnail.jpg"; $filename = 'curl.jpg'; getImg($url, $filename); /* *@通过curl方式获取制定的图片到本地 *@ 完整的图片地址 *@ 要存储的文件名 */ function getImg($url = "", $filename = "") { if(is_dir(basename($filename))) { echo "The Dir was not exits"; return false; } //去除URL连接上面可能的引号 $url = preg_replace( '/(?:^['"]+|['"/]+$)/', '', $url ); $hander = curl_init(); $fp = fopen($filename,'wb'); curl_setopt($hander,CURLOPT_URL,$url); curl_setopt($hander,CURLOPT_FILE,$fp); curl_setopt($hander,CURLOPT_HEADER,0); curl_setopt($hander,CURLOPT_FOLLOWLOCATION,1); //curl_setopt($hander,CURLOPT_RETURNTRANSFER,false);//以数据流的方式返回数据,当为false是直接显示出来 curl_setopt($hander,CURLOPT_TIMEOUT,60); /*$options = array( CURLOPT_URL=> '/thum-f3ccdd27d2000e3f9255a7e3e2c4880020110622095243.jpg', CURLOPT_FILE => $fp, CURLOPT_HEADER => 0, CURLOPT_FOLLOWLOCATION => 1, CURLOPT_TIMEOUT => 60 ); curl_setopt_array($hander, $options); */ curl_exec($hander); curl_close($hander); fclose($fp); return true; } ?>
curl_setopt définit une option pour les appels CURL
bool curl_setopt (int ch, option chaîne, valeur mixte)
La fonction curl_setopt() définira les options pour une session CURL. Le paramètre option est le paramètre souhaité et value est la valeur donnée par cette option.
Les valeurs des options suivantes seront utilisées sous forme d'entiers longs (spécifiés dans le paramètre option) :
CURLOPT_INFILESIZE : Lorsque vous téléchargez un fichier sur le site distant, cette option indique à PHP la taille du fichier que vous avez téléchargé.
CURLOPT_VERBOSE : Si vous souhaitez que CURL signale chaque événement inattendu, définissez cette option sur une valeur non nulle.
CURLOPT_HEADER : Si vous souhaitez inclure un en-tête dans la sortie, définissez cette option sur une valeur non nulle.
CURLOPT_NOPROGRESS : Si vous ne souhaitez pas que PHP affiche une barre de progression pour les transferts CURL, définissez cette option sur une valeur non nulle.
Remarque : PHP définit automatiquement cette option sur une valeur non nulle, vous ne devez modifier cette option qu'à des fins de débogage.
CURLOPT_NOBODY : Si vous ne souhaitez pas inclure la partie du corps dans la sortie, définissez cette option sur une valeur non nulle.
CURLOPT_FAILONERROR : Si vous souhaitez que PHP ne s'affiche pas lorsqu'une erreur se produit (le code HTTP renvoie supérieur ou égal à 300), définissez cette option sur une valeur non nulle. Le comportement par défaut consiste à renvoyer une page normale et à ignorer le code.
CURLOPT_UPLOAD : Si vous souhaitez que PHP prépare le téléchargement, définissez cette option sur une valeur non nulle.
CURLOPT_POST : Si vous souhaitez que PHP effectue un HTTP POST régulier, définissez cette option sur une valeur non nulle. Ce POST est du type application/x-www-from-urlencoded ordinaire, principalement utilisé par les formulaires HTML.
CURLOPT_FTPLISTONLY : définissez cette option sur une valeur non nulle et PHP répertoriera les noms de répertoires pour FTP.
CURLOPT_FTPAPPEND : définissez cette option sur une valeur non nulle et PHP appliquera le fichier distant au lieu de l'écraser.
CURLOPT_NETRC : Définissez cette option sur une valeur non nulle et PHP recherchera dans votre fichier ~./netrc le nom d'utilisateur et le mot de passe du site distant auquel vous souhaitez vous connecter.
CURLOPT_FOLLOWLOCATION : Définissez cette option sur une valeur non nulle (comme "Location : "), le serveur l'enverra dans le cadre de l'en-tête HTTP (notez que ceci est récursif, PHP Un en-tête du type "Location : " sera envoyé).
CURLOPT_PUT : Définissez cette option sur une valeur non nulle pour télécharger un fichier via HTTP. Pour télécharger ce fichier, vous devez définir les options CURLOPT_INFILE et CURLOPT_INFILESIZE.
CURLOPT_MUTE : Définissez cette option sur une valeur non nulle et PHP sera complètement silencieux pour la fonction CURL.
CURLOPT_TIMEOUT : Définissez un nombre entier long comme nombre maximum de secondes.
CURLOPT_LOW_SPEED_LIMIT : Définissez un entier long pour contrôler le nombre d'octets envoyés.
CURLOPT_LOW_SPEED_TIME : Définissez un entier long pour contrôler le nombre de secondes de transmission du nombre d'octets spécifié par CURLOPT_LOW_SPEED_LIMIT.
CURLOPT_RESUME_FROM : Transmettez un paramètre long contenant l'adresse de décalage d'octet (le formulaire de démarrage vers lequel vous souhaitez transférer).
CURLOPT_SSLVERSION : Passer un paramètre long contenant la version SSL. Par défaut PHP sera déterminé par ses propres efforts, pour plus de sécurité vous devrez le paramétrer manuellement.
CURLOPT_TIMECONDITION : Transmettez un paramètre long pour spécifier comment gérer le paramètre CURLOPT_TIMEVALUE. Vous pouvez définir ce paramètre sur TIMECOND_IFMODSINCE ou TIMECOND_ISUNMODSINCE. Ceci est uniquement pour HTTP.
CURLOPT_TIMEVALUE : Passe un certain nombre de secondes de 1970-1-1 à maintenant. Cette heure sera utilisée comme valeur spécifiée par l'option CURLOPT_TIMEVALUE, ou par la valeur par défaut TIMECOND_IFMODSINCE.
Les valeurs des options suivantes seront traitées comme des chaînes :
CURLOPT_URL : Il s'agit de l'adresse URL que vous souhaitez récupérer à l'aide de PHP. Vous pouvez également définir cette option lors de l'initialisation avec la fonction curl_init().
CURLOPT_USERPWD : Passez une chaîne sous la forme de [nom d'utilisateur]:[mot de passe] et utilisez PHP pour vous connecter.
CURLOPT_PROXYUSERPWD : Passez une chaîne au format [nom d'utilisateur]:[mot de passe] pour vous connecter au proxy HTTP.
CURLOPT_RANGE : Transmettez une plage que vous souhaitez spécifier. Il doit être au format "X-Y", X ou Y étant exclus. Les transferts HTTP prennent également en charge plusieurs intervalles, séparés par des virgules (X-Y, N-M).
CURLOPT_POSTFIELDS : Transmettez une chaîne contenant toutes les données en tant qu'opération HTTP "POST".
CURLOPT_REFERER : Une chaîne contenant un en-tête "referer" dans la requête HTTP.
CURLOPT_USERAGENT : Une chaîne contenant un en-tête "user-agent" dans la requête HTTP.
CURLOPT_FTPPORT : Passer une adresse IP contenant l'adresse IP utilisée par la commande ftp "POST". Cette commande POST indique au serveur distant de se connecter à l'adresse IP que nous avons spécifiée. Cette chaîne peut être une adresse IP, un nom d'hôte, un nom d'interface réseau (sous UNIX) ou '-' (utilisez l'adresse IP par défaut du système).
CURLOPT_COOKIE : Passez un en-tête de connexion contenant un cookie HTTP.
CURLOPT_SSLCERT : Passe une chaîne contenant le certificat au format PEM.
CURLOPT_SSLCERTPASSWD : Passez un mot de passe contenant le mot de passe nécessaire pour utiliser le certificat CURLOPT_SSLCERT.
CURLOPT_COOKIEFILE : Transmettez une chaîne contenant le nom du fichier contenant les données du cookie. Ce fichier cookie peut être au format Netscape ou il peut s'agir d'une pile d'en-têtes de style HTTP stockés dans le fichier.
CURLOPT_CUSTOMREQUEST : Lors d'une requête HTTP, transmettez un caractère à utiliser par GET ou HEAD.
Ce qui précède explique comment PHP utilise curl pour obtenir des images distantes. J'espère que cela sera utile à l'apprentissage de chacun.