这是我的代码;
<?php $url = @$_POST["ekleme"];
if (filter_var($url,FILTER_VALIDATE_URL) === FALSE) {
die("Geçersiz link!");
}
$cparams = array('http'=>array('method'=>"GET",'Accept'=>'image/jpg,image/gif,image/png'));
$context = stream_context_create($cparams);
$fp = @fopen($url, 'rb', false, $context);
if (!$fp) die("Problem with url");
$meta = stream_get_meta_data($fp);
var_dump($meta);
我给它一个 pdf 文件的网址。我希望它会给出某种 http 错误。但这就是我得到的;
array(10) {
["wrapper_data"]=>
array(9) {
[0]=>
string(15) "HTTP/1.1 200 OK"
[1]=>
string(35) "Date: Wed, 02 Jan 2013 14:16:02 GMT"
[2]=>
string(14) "Server: Apache"
[3]=>
string(44) "Last-Modified: Wed, 19 Dec 2012 13:53:09 GMT"
[4]=>
string(34) "ETag: "1c80e53-f5a7-4d134ef3b7b40""
[5]=>
string(20) "Accept-Ranges: bytes"
[6]=>
string(21) "Content-Length: 62887"
[7]=>
string(29) "Content-Type: application/pdf"
[8]=>
string(17) "Connection: close"
}
它继续显示其他不相关的东西。我是否知道 Accept header 是如何工作的,还是我做错了什么?如果内容类型是特定的,有没有办法让服务器只发送数据?
最佳答案
Accept 头让客户端告诉服务器它可以处理什么类型的数据。
服务器可能会完全忽略它(如果资源仅以一种格式存在,这是正常的),或者它可能会使用它来选择最适合客户端的格式(如果它没有适当格式的数据)。
您正在经历前一种行为。 URL 指向一个 PDF 文件。服务器未设置为在 PDF 和其他格式之间做出决定,因此它不会注意 Accept header 并返回 PDF。
接受 header 尽可能接近。
如果您想避免下载可能无法处理的大文件,请在发出 GET 请求之前发出 HEAD 请求并检查响应的 Content-Type。
关于php - http Accept header 如何工作?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14123658/