您的位置:首页 > 理论基础 > 计算机网络

php根据Http请求头部信息下载文件

2017-09-07 11:26 483 查看
朋友遇到一个问题,php访问一个下载地址,获得的只有地址的请求值,而没有问题,经过大神的指导发现,原来下载地址有经过校验,要在浏览器环境下才能下载,用php的header模拟浏览器环境,就能下载了。大神的解决方法:先用浏览器访问这个地址,获得这个地址的头部信息

在代码里模拟浏览器访问。大神的代码如下:

function getpdf($url){

   $header=[

      'Host:xxxx',

      'User-Agent:Mozilla/5.0 (Windows NT 10.0; WOW64; rv:55.0) Gecko/20100101 Firefox/55.0',

      'Accept:text/html,/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',

      'Accept-Language:en-US,applicationzh-CN;q=0.8,zh;q=0.5,en;q=0.3',

      'Accept-Encoding:gzip, deflate',

      'Connection:keep-alive',

      'Upgrade-Insecure-Requests:1'

   ];

   

  

       $ch = curl_init(); 

    $fp=fopen('girl.pdf', 'w');

    curl_setopt($ch, CURLOPT_URL, $url); 

    curl_setopt($ch, CURLOPT_FILE, $fp); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);  

    

    $output = curl_exec($ch); 

    curl_close($ch); 
file_put_contents('dowm.pdf', $output);
echo $output;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐