Maison >développement back-end >Problème PHP >PHP détermine si le lien est une image

PHP détermine si le lien est une image

尚
original
2019-10-28 16:21:056257parcourir

PHP détermine si le lien est une image

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 = &#39;http://www.example.com&#39;;

print_r(get_headers($url));

print_r(get_headers($url, 1));
?>
rrree

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!

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