我解除了以下PHP代码,以便查找用户的位置信息,这将使我能够执行某些级别的限制。
但是,代码在我的localhost服务器上运行良好。但是当我将相同的php文件上传到我的远程Web服务器时,它会返回错误:
警告: 的file_get_contents(http://api.codehelper.io/ips/?php&ip=192.168.1.1): 无法打开流:权限被拒绝 /home/www/xyberinternational.com/lotto247.biz/visitorlocation/userip/ip.codehelper.io.php 在第41行。
我在下面列出了以下文件及其代码。我该如何解决这个错误?
<?php
require_once("userip/ip.codehelper.io.php");
require_once("userip/php_fast_cache.php");
$_ip = new ip_codehelper();
$real_client_ip_address = $_ip->getRealIP();
$visitor_location = $_ip->getLocation($real_client_ip_address);
$guest_ip = $visitor_location['IP'];
$guest_country = $visitor_location['CountryName'];
$guest_city = $visitor_location['CityName'];
$guest_state = $visitor_location['RegionName'];
echo "IP Address: ". $guest_ip. "<br/>";
echo "Country: ". $guest_country. "<br/>";
echo "State: ". $guest_state. "<br/>";
echo "City: ". $guest_city. "<br/>";
$ip = $visitor_location['IP'];
$Continent_Code = $visitor_location['ContinentCode'];
$Continent_Name = $visitor_location['ContinentName'];
$Country_Code2 = $visitor_location['CountryCode2'];
$Country_Code3 = $visitor_location['CountryCode3'];
$Country = $visitor_location['Country'];
$Country_Name = $visitor_location['CountryName'];
$State_Name = $visitor_location['RegionName'];
$City_Name = $visitor_location['CityName'];
$City_Latitude = $visitor_location['CityLatitude'];
$City_Longitude = $visitor_location['CityLongitude'];
$Country_Latitude = $visitor_location['CountryLatitude'];
$Country_Longitude = $visitor_location['CountryLongitude'];
$Country_Longitude = $visitor_location['CountryLongitude'];
$LocalTimeZone = $visitor_location['LocalTimeZone'];
$Calling_Code = $visitor_location['CallingCode'];
$Population = $visitor_location['Population'];
$Area_SqKm = $visitor_location['AreaSqKm'];
$Capital = $visitor_location['Capital'];
$Electrical = $visitor_location['Electrical'];
$Languages = $visitor_location['Languages'];
$Currency = $visitor_location['Currency'];
$Flag = $visitor_location['Currency'];
?>
<?php
class ip_codehelper {
public function getRealIP() {
$ipaddress = '';
if(isset($_SERVER['HTTP_CF_CONNECTING_IP'])) {
$ipaddress = $_SERVER['HTTP_CF_CONNECTING_IP'];
} else if (isset($_SERVER['HTTP_X_REAL_IP'])) {
$ipaddress = $_SERVER['HTTP_X_REAL_IP'];
}
else if (isset($_SERVER['HTTP_CLIENT_IP']))
$ipaddress = $_SERVER['HTTP_CLIENT_IP'];
else if(isset($_SERVER['HTTP_X_FORWARDED_FOR']))
$ipaddress = $_SERVER['HTTP_X_FORWARDED_FOR'];
else if(isset($_SERVER['HTTP_X_FORWARDED']))
$ipaddress = $_SERVER['HTTP_X_FORWARDED'];
else if(isset($_SERVER['HTTP_FORWARDED_FOR']))
$ipaddress = $_SERVER['HTTP_FORWARDED_FOR'];
else if(isset($_SERVER['HTTP_FORWARDED']))
$ipaddress = $_SERVER['HTTP_FORWARDED'];
else if(isset($_SERVER['REMOTE_ADDR']))
$ipaddress = $_SERVER['REMOTE_ADDR'];
else
$ipaddress = 'UNKNOWN';
return $ipaddress;
}
public function getLocation($ip="") {
if($ip == "") {
$ip = $this->getRealIP();
}
if(!class_exists("phpFastCache")) {
die("Please required phpFastCache Class");
}
// you should change this to cURL()
$data = phpFastCache::get("codehelper_ip_".md5($ip));
// caching 1 week
if($data == null) {
$url = "http://api.codehelper.io/ips/?callback=codehelper_ip_callback&ip=".$ip;
$json = file_get_contents($url);
$data = json_decode($json,true);
phpFastCache::set("codehelper_ip_".md5($ip),$data,3600*24*7);
}
return $data;
}
public function SSLForwardJS() {
$ip = $this->getRealIP();
if(!class_exists("phpFastCache")) {
die("Please required phpFastCache Class");
}
// you should change this to cURL()
$data = phpFastCache::get("codehelper_ip_ssl".md5($ip));
// caching 1 week
if($data == null) {
$url = "http://api.codehelper.io/ips/?callback=codehelper_ip_callback&ip=".$ip;
$data = file_get_contents($url);
phpFastCache::set("codehelper_ip_ssl".md5($ip),$data,3600*24*7);
}
return $data;
}
}
同时,fastcatch.php非常大。
答案 0 :(得分:1)
这是你的问题:
$url = "http://api.codehelper.io/ips/?callback=codehelper_ip_callback&ip=".$ip;
$data = file_get_contents($url);
(靠近ip.coderhelper.io.php文件的底部)
这会引发错误,因为您尝试从中获取数据的服务器拒绝您访问该文件。你有几个选择:
1)与codehelper.io工作人员交谈,看看你服务器的IP是否被列入黑名单或一般范围(有时候,取决于你从公司购买服务器的位置黑名单IP,因为他们知道发送出去恶意攻击或请求。让他们看看他们是否可以解决问题。
2)如果这不是一个可行的选择,你可以看看this post,第二个答案有一点hacky工作。值得一试。