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

来源:互联网 发布:淘宝男模特 编辑:程序博客网 时间:2024/06/05 11:41

朋友遇到一个问题,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;
}