ホームページ  >  記事  >  バックエンド開発  >  PHPはリンクが画像かどうかを判断します

PHPはリンクが画像かどうかを判断します

尚
オリジナル
2019-10-28 16:21:056185ブラウズ

PHPはリンクが画像かどうかを判断します

方法 1

URL リンクを .png、.gif、.jpg、.jpeg と直接照合します。

preg_match('/.*(\.png|\.jpg|\.jpeg|\.gif)$/', $url);

これは最も簡単な方法ですが、すべての画像リンクが画像名拡張子で終わるわけではないため、十分正確ではありません。

方法 2

CURL を使用して画像 URL の応答ヘッダーを取得します

まず、curl を作成し、ヘッダー ファイルの情報をデータとして出力します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);

このとき、コンテンツにはヘッダー情報と画像のバイナリ コンテンツが含まれており、ヘッダーのサイズ ($headerSize) に応じてヘッダー情報をインターセプトし、残りはバイナリです画像の内容。

$headers = substr($content, 0, $headerSize); //根据头大小截取头信息

ヘッダー情報の出力構造は以下のとおりです

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

Content-Type:image/jpegがあることがわかり、ヘッダー情報を加工して目的のコンテンツを取り出します

$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 {//否则........
 ............
}

方法 3

PHP の get_headers() 関数を使用すると、応答ヘッダー情報を直接取得できますが、curl と比較してタイムアウトを設定することができません。

<?php
$url = &#39;http://www.example.com&#39;;

print_r(get_headers($url));

print_r(get_headers($url, 1));
?>
Array
(
    [0] => HTTP/1.1 200 OK
    [1] => Date: Sat, 29 May 2004 12:28:13 GMT
    [2] => Server: Apache/1.3.27 (Unix)  (Red-Hat/Linux)
    [3] => Last-Modified: Wed, 08 Jan 2003 23:11:55 GMT
    [4] => ETag: "3f80f-1b6-3e1cb03b"
    [5] => Accept-Ranges: bytes
    [6] => Content-Length: 438
    [7] => Connection: close
    [8] => Content-Type: text/html
)

Array
(
    [0] => HTTP/1.1 200 OK
    [Date] => Sat, 29 May 2004 12:28:14 GMT
    [Server] => Apache/1.3.27 (Unix)  (Red-Hat/Linux)
    [Last-Modified] => Wed, 08 Jan 2003 23:11:55 GMT
    [ETag] => "3f80f-1b6-3e1cb03b"
    [Accept-Ranges] => bytes
    [Content-Length] => 438
    [Connection] => close
    [Content-Type] => text/html
)

推奨: php サーバー

以上がPHPはリンクが画像かどうかを判断しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。