我在从 PHP 代码调用 url 时遇到问题。我需要使用 PHP 代码中的查询字符串来调用服务。如果我在浏览器中输入 url,它可以正常工作,但如果我使用 file-get-contents() 进行调用,我会得到:
警告:file-get-contents(http://....) 无法打开流:HTTP 请求失败! HTTP/1.1 202 已接受...
我使用的代码是:
$query=file_get_contents('http://###.##.##.##/mp/get?mpsrc=http://mybucket.s3.amazonaws.com/11111.mpg&mpaction=convert format=flv');
echo($query);
就像我说的 - 从浏览器调用,它工作正常。有什么建议吗?
我还尝试过另一个网址,例如:
$query=file_get_contents('http://www.youtube.com/watch?v=XiFrfeJ8dKM');
这工作正常...我需要调用的网址是否有第二个
http://
?
尝试使用 cURL。
<?php
$curl_handle=curl_init();
curl_setopt($curl_handle, CURLOPT_URL,'http://###.##.##.##/mp/get?mpsrc=http://mybucket.s3.amazonaws.com/11111.mpg&mpaction=convert format=flv');
curl_setopt($curl_handle, CURLOPT_CONNECTTIMEOUT, 2);
curl_setopt($curl_handle, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl_handle, CURLOPT_USERAGENT, 'Your application name');
$query = curl_exec($curl_handle);
curl_close($curl_handle);
?>
<?php
$lurl=get_fcontent("http://ip2.cc/?api=cname&ip=84.228.229.81");
echo"cid:".$lurl[0]."<BR>";
function get_fcontent( $url, $javascript_loop = 0, $timeout = 5 ) {
$url = str_replace( "&", "&", urldecode(trim($url)) );
$cookie = tempnam ("/tmp", "CURLCOOKIE");
$ch = curl_init();
curl_setopt( $ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; rv:1.7.3) Gecko/20041001 Firefox/0.10.1" );
curl_setopt( $ch, CURLOPT_URL, $url );
curl_setopt( $ch, CURLOPT_COOKIEJAR, $cookie );
curl_setopt( $ch, CURLOPT_FOLLOWLOCATION, true );
curl_setopt( $ch, CURLOPT_ENCODING, "" );
curl_setopt( $ch, CURLOPT_RETURNTRANSFER, true );
curl_setopt( $ch, CURLOPT_AUTOREFERER, true );
curl_setopt( $ch, CURLOPT_SSL_VERIFYPEER, false ); # required for https urls
curl_setopt( $ch, CURLOPT_CONNECTTIMEOUT, $timeout );
curl_setopt( $ch, CURLOPT_TIMEOUT, $timeout );
curl_setopt( $ch, CURLOPT_MAXREDIRS, 10 );
$content = curl_exec( $ch );
$response = curl_getinfo( $ch );
curl_close ( $ch );
if ($response['http_code'] == 301 || $response['http_code'] == 302) {
ini_set("user_agent", "Mozilla/5.0 (Windows; U; Windows NT 5.1; rv:1.7.3) Gecko/20041001 Firefox/0.10.1");
if ( $headers = get_headers($response['url']) ) {
foreach( $headers as $value ) {
if ( substr( strtolower($value), 0, 9 ) == "location:" )
return get_url( trim( substr( $value, 9, strlen($value) ) ) );
}
}
}
if ( ( preg_match("/>[[:space:]]+window\.location\.replace\('(.*)'\)/i", $content, $value) || preg_match("/>[[:space:]]+window\.location\=\"(.*)\"/i", $content, $value) ) && $javascript_loop < 5) {
return get_url( $value[1], $javascript_loop+1 );
} else {
return array( $content, $response );
}
}
?>
file_get_contents()
使用 fopen()
包装器,因此限制它通过 php.ini 中的 allow_url_fopen
选项访问 URL。
您需要更改 php.ini 来打开此选项,或者使用替代方法,即 cURL - 迄今为止最流行的、说实话,也是完成您想要做的事情的标准方法。
您基本上需要随请求发送一些信息。
试试这个,
$opts = array('http'=>array('header' => "User-Agent:MyAgent/1.0\r\n"));
//Basically adding headers to the request
$context = stream_context_create($opts);
$html = file_get_contents($url,false,$context);
$html = htmlspecialchars($html);
这对我来说很有效
我注意到您的网址中有空格。我认为这通常是一件坏事。尝试使用
对 URL 进行编码$my_url = urlencode("my url");
然后打电话
file_get_contents($my_url);
看看你是否有更好的运气。
我也遇到了类似的问题。
由于超时!
超时可以这样指示:
$options = array(
'http' => array(
'header' => "Content-type: application/x-www-form-urlencoded\r\n",
'method' => "POST",
'content' => http_build_query($data2),
'timeout' => 30,
),
);
$context = stream_context_create($options);
$retour = @file_get_contents("http://xxxxx.xxx/xxxx", false, $context);
我遇到了类似的问题,我解析了 youtube url。代码是;
$json_is = "http://gdata.youtube.com/feeds/api/videos?q=".$this->video_url."&max-results=1&alt=json";
$video_info = json_decode ( file_get_contents ( $json_is ), true );
$video_title = is_array ( $video_info ) ? $video_info ['feed'] ['entry'] [0] ['title'] ['$t'] : '';
然后我意识到
$this->video_url
包含空格。我用trim($this->video_url)
解决了这个问题。
也许会对你有帮助。祝你好运
这个功能解决了我的问题
function file_get_contents_curl($url) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //Set curl to return the data instead of printing it to the browser.
curl_setopt($ch, CURLOPT_URL, $url);
$data = curl_exec($ch);
curl_close($ch);
return $data;
}
我不确定参数(mpaction、格式)是否是为 amazonaws 页面或 ##.## 指定的。
尝试 urlencode() url。
$query=file_get_contents('http://###.##.##.##/mp/get?' . http_build_query(array('mpsrc' => 'http://mybucket.s3.amazonaws.com/11111.mpg&mpaction=convert format=flv')));
这对我不起作用,我得到的结果查询为空值。所以我检查了邮递员,看看 api 是否确实返回了值,确实如此。邮递员在右侧有这个选项卡,您可以在其中获取用于获取结果的示例代码,并在尝试后最终成功,但最初您可能会收到一个奇怪的错误 411,指出需要指定帖子长度,我添加了修复程序在我下面的代码中。要绕过 411 POST 长度错误,请创建一个空数组并使用 http_build_query 函数。然后在 CURLOPT_POSTFIELDS 卷曲选项中设置该变量。
$data_string = array();
$curl = curl_init();
$test = http_build_query($data_string);
curl_setopt_array($curl, array(
CURLOPT_URL => 'https://www.googleapis.com/geolocation/v1/geolocate?key=APIKEY',
CURLOPT_POSTFIELDS => $test,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => '',
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 0,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => 'POST',
));
$response = curl_exec($curl);
curl_close($curl);
echo $response;
这对我有用......我没有使用curl。
我能够通过浏览器访问特定的 API url,但在 file_get_contents 中使用时,出现错误“无法打开流”。
然后,我通过使用 urlencoding 对所有双引号进行编码来修改我想要调用的 API URL,并保持其他所有内容不变。
示例格式如下:
$url = 'https://stackoverflow.com/questions'.urlencode('"'.$variable1.'"');
然后使用
file_get_contents($url);
有同样的问题,但这是一个防火墙问题...一旦我将 API 服务器列入白名单,它就可以正常工作,使用 get_file_contents($url) 和上面的curl方法...
在发现防火墙规则问题之前浪费了几个小时。
对我来说,问题是
Content-Length
标头中的值不正确。该值太大了,所以 nginx 一直在等待其余从未到达的内容。
就我而言,我必须指定多个标头:
$headers = [
'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.102 Safari/537.36', // User-Agent header
'Accept-Language: en-US,en;q=0.5',
'Cache-Control: no-cache',
'Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
'Connection: keep-alive',
'Accept-Encoding: gzip, deflate, br',
];
$options = [
'http' => [
'method' => 'HEAD',
'timeout' => 3, // Timeout in seconds
'header' => implode("\r\n", $headers)
],
];
set_error_handler("exception_error_handler");
$context = stream_context_create($options);
$headers = get_headers($url, false, $context);
我建议在邮递员或网络浏览器中尝试该 URL,并检查使用了哪些标头并模仿它。
用这个
file_get_contents($my_url,null,null);