Méthode 1
Correspondance directe et régulière des liens URL, qu'ils se terminent par .png, .gif, .jpg, .jpeg.
preg_match('/.*(\.png|\.jpg|\.jpeg|\.gif)$/', $url);
C'est le moyen le plus simple, mais il n'est pas assez précis car tous les liens d'image ne se terminent pas par le nom de l'image + l'extension.
Méthode 2
Utilisez CURL pour obtenir l'en-tête de réponse de l'URL de l'image
Créez d'abord une boucle et affichez les informations du fichier d'en-tête sous forme de données stream
$url = "http://*************"; //图片的链接地址 $ch = curl_init(); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); //是否跟着爬取重定向的页面 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //将curl_exec()获取的值以文本流的形式返回,而不是直接输出。 curl_setopt($ch, CURLOPT_HEADER, 1); // 启用时会将头文件的信息作为数据流输出 curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5); //设置超时时间 curl_setopt($ch, CURLOPT_URL, $url); //设置URL $content = curl_exec($ch); $httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE); //curl的httpcode $headerSize = curl_getinfo($ch, CURLINFO_HEADER_SIZE); //获取头大小 curl_close($ch);
À ce moment, le contenu contient les informations d'en-tête et le contenu binaire de l'image, puis intercepte les informations d'en-tête en fonction de la taille de l'en-tête ($headerSize), et le reste est le binaire contenu de l'image.
$headers = substr($content, 0, $headerSize); //根据头大小截取头信息
La structure de sortie des informations d'en-tête est la suivante
HTTP/1.1 200 OK Server: JSP3/2.0.14 Date: Sun, 30 Jul 2017 06:54:47 GMT Content-Type: image/jpeg Content-Length: 152094 Connection: keep-alive ETag: "7751852900776331536" Last-Modified: Tue, 02 May 2017 10:33:16 GMT Expires: Wed, 18 Jul 2018 06:25:38 GMT Age: 879492 Cache-Control: max-age=31536000 Accept-Ranges: bytes Error-Message: OK Ohc-Response-Time: 1 0 0 0 0 0
Vous pouvez voir qu'il y a Content-Type : image/jpeg, puis traiter les informations d'en-tête et supprimer le contenu souhaité
$head_data=preg_split('/\n/',$headers); //逐行放入数组中 $head_data = array_filter($head_data); //过滤空数组 $headers_arr = []; foreach($head_data as $val){ //按:分割开 list($k,$v) = explode(":",$val); //:前面的作为key,后面的作为value,放入数组中 $headers_arr[$k] = $v; } $img_type = explode("/",trim($headers_arr['Content-Type'])); //然后将获取到的Content-Type中的值用/分隔开 if ($httpcode == 200 && strcasecmp($img_type[0],'image') == 0) {//如果httpcode为200,并且Content-type前面的部分为image,则说明该链接可以访问成功,并且是一个图片类型的 $type = $img_type[1]; ............. } else {//否则........ ............ }
Méthode 3
En utilisant la fonction get_headers() de PHP, vous pouvez obtenir directement les informations d'en-tête de réponse, mais par rapport à curl, vous ne pouvez pas définir de délai d'attente.
<?php $url = 'http://www.example.com'; print_r(get_headers($url)); print_r(get_headers($url, 1)); ?>
Recommandé : serveur php
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!