上記のコードを簡単に説明します。 get_headers の機能は、リモート アドレスにアクセスし、サーバーから送信された HTTP ヘッダーを配列の形式で返すことです。 $header[0] はサーバーから返されるステータス コードです (他に何も起こらなければ、ステータス コードが最初に返されるはずです)。
ファイルがリモート サーバー上に存在するかどうかを判断するには、ファイルにアクセスして返されたステータス コードが「HTTP/1.1 200 OK」であることを確認するだけです (もちろん、ステータス コードが「HTTP/1.1 404 Not」でないかどうかを判断することもできます) 「見つかりました」) ファイルは存在しますが、常に安全ではないと感じます。結局のところ、301、400 などの他のステータス コードもあります)。
3 桁の HTTP 応答コードを取得する例:
関数 get_http_response_code($theURL) {
$headers = get_headers($theURL);
substr($headers[0], 9, 3) を返します。}
?>
リダイレクトを除外する例:
/**
* リダイレクトなしで、HTTP リクエストに応じてサーバーから送信されたすべての実際のヘッダーを取得します
* リダイレクトせずにヘッダーを取得します
*/
function get_real_headers($url,$format=0,$follow_redirect=0) {
if (!$follow_redirect) {
// 新しいデフォルトオプションを設定します
$opts = array('http' =>
array('max_redirects'=>1,'ignore_errors'=>1)
);
Stream_context_get_default($opts);
}
//ヘッダーを取得します
$headers=get_headers($url,$format);
// デフォルトのオプションを復元します
if (isset($opts)) {
$opts = array('http' =>
array('max_redirects'=>20,'ignore_errors'=>0)
);
Stream_context_get_default($opts);
}
//戻る
$headers を返します;
}
?>
この記事への固定リンク: http://www.xssxss.com/fuck/323.xss | Shine's Holy Paradise-〃ミン〃
http://www.bkjia.com/PHPjc/478544.html