使用visitor ip从页面中抓取网址

时间:2018-05-31 09:59:24

标签: php curl scrape

我使用以下代码从网站制作视频网址的get_file_contents:

<?php $get = file_get_contents("https://vidhd.net/embed-bc3c7z8e8pmt.html");
    $regex = '/(https|http)[^"]*(?=",label)/';
    if (preg_match_all($regex, $get, $allurlget)){
     foreach($allurlget[0] as $getlist) {
          $TakeJsonToList[] = $getlist;}
           if (count($TakeJsonToList) == 3){
               $Makejson =  array ('p720' => $TakeJsonToList[0],
                                    'p480' => $TakeJsonToList[1],
                                    'p360' => $TakeJsonToList[2]);
          }else if (count($TakeJsonToList) == 2){
               $Makejson =  array ('p720' => $TakeJsonToList[0],
                                    'p480' => $TakeJsonToList[1]);
          }else{
               $Makejson =  array ('p720' => $TakeJsonToList[0]);
          }
    echo json_encode($Makejson);}
        else{
            $filenotfound = 'Url Not Found';
            $error = json_encode(array('error'=> $filenotfound));
        echo ($error);
    }

现在我把输出视为json像这样:

{"p720":"https:\/\/s4.vidhd.net\/kmxssvaapjumwmesrlvuyy72hjmxnedreq2ahr5kil6qqt373orzkuun4ccq\/v.mp4","p480":"https:\/\/s4.vidhd.net\/kmxssvaapjumwmesrlvuyy72hjmxnedreq2ahr5kiriqqt373or7r273xqrq\/v.mp4"}

但是,当我向另一个网站提出请求时,&#34; Vidhd&#34;         用我的网站ip制作视频网址。         所以,当我播放视频时,我得到了错误的IP!是的,因为url ip是我的网站ip而不是我的电脑ip         我需要的 ?         我需要使用访客ip而不是服务器ip发出请求谢谢。

1 个答案:

答案 0 :(得分:0)

从vidhd.net的角度来看,用于获取视频的ip(通过直接视频文件url)必须与请求视频的ip相同。所以要么直接从php流式传输视频(例如,使用readfile()),要么直接从vistor的ip中获取视频URL(例如,通过javascript / XMLHttpRequest)

第一种方法有使用更多带宽的缺点,因为整个视频必须下载到您的服务器并提供给客户端,使您的服务器的带宽使用量为电影的2倍。第二种方法的缺点是,您可能会遇到CORS restrictions从javascript执行此操作,除非vidhd通过CORS-Allow headers明确允许CORS请求,并且根据curl,它们不会:< / p>

$ curl -I https://vidhd.net/embed-bc3c7z8e8pmt.html
HTTP/1.1 200 OK
Server: nginx
Date: Thu, 31 May 2018 13:25:56 GMT
Content-Type: text/html; charset=UTF-8
Connection: keep-alive
Expires: Wed, 30 May 2018 13:25:56 GMT
X-frame-options: 1
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block

虽然你可能只能使用iframe,除非他们阻止iframe,谁知道。