Другими словами, как я могу узнать, находится ли человек, использующий мое веб-приложение, на сервере, на котором он находится? Если я правильно помню, PHPMyAdmin делает что-то вроде этого по соображениям безопасности.
Как определить, находится ли пользователь на локальном хосте в PHP?
Ответ 1
Вы также можете использовать $_SERVER['REMOTE_ADDR']
, для которого IP-адрес запроса клиента предоставляется веб-сервером.
$whitelist = array(
'127.0.0.1',
'::1'
);
if(!in_array($_SERVER['REMOTE_ADDR'], $whitelist)){
// not valid
}
Ответ 2
Как дополнение, как функция...
function isLocalhost($whitelist = ['127.0.0.1', '::1']) {
return in_array($_SERVER['REMOTE_ADDR'], $whitelist);
}
Ответ 3
$_SERVER["REMOTE_ADDR"]
должен указать вам IP-адрес пользователя. Это пригодится, однако.
Проверьте этот вопрос о бонусе для подробного обсуждения.
Я думаю, что то, что вы помните, с PHPMyAdmin - это нечто другое: многие серверы MySQL настроены так, что к ним можно получить доступ только из localhost по соображениям безопасности.
Ответ 4
Более новые пользователи ОС (Win 7, 8) также могут потребовать включения удаленного адреса IPV6 в свой белый список:
$whitelist = array('127.0.0.1', "::1");
if(!in_array($_SERVER['REMOTE_ADDR'], $whitelist)){
// not valid
}
Ответ 5
Кажется, вы не должны использовать $_SERVER['HTTP_HOST']
, потому что это значение в заголовке http, легко подделано.
Вы можете использовать $_SERVER["REMOTE_ADDR"]
тоже, это более безопасное значение, но также можно подделать. Этот remote_addr
- это адрес, где Apache возвращает результат.
Ответ 6
Если вы хотите иметь белый список/список разрешений, который поддерживает статические IP-адреса и динамические имена.
Например:
$whitelist = array("localhost", "127.0.0.1", "devel-pc.ds.com", "liveserver.com");
if (!isIPWhitelisted($whitelist)) die();
Таким образом вы можете установить список имен/IP-адресов, которые будут (наверняка) обнаружены. Динамические имена добавляют дополнительную гибкость для доступа из разных точек.
Здесь у вас есть два общих варианта: вы можете указать имя в файле локальных хостов или просто использовать один поставщик динамических имен, который можно найти где угодно.
Эта функция CACHES приводит к тому, что gethostbyname является очень медленной функцией.
Для этой куколки я реализовал эту функцию:
function isIPWhitelisted($whitelist = false)
{
if ( isset($_SESSION) && isset($_SESSION['isipallowed']) )
{ return $_SESSION['isipallowed']; }
// This is the whitelist
$ipchecklist = array("localhost", "127.0.0.1", "::1");
if ($whitelist) $ipchecklist = $whitelist;
$iplist = false;
$isipallowed = false;
$filename = "resolved-ip-list.txt";
$filename = substr(md5($filename), 0, 8)."_".$filename; // Just a spoon of security or just remove this line
if (file_exists($filename))
{
// If cache file has less than 1 day old use it
if (time() - filemtime($filename) <= 60*60*24*1)
$iplist = explode(";", file_get_contents($filename)); // Read cached resolved ips
}
// If file was not loaded or found -> generate ip list
if (!$iplist)
{
$iplist = array(); $c=0;
foreach ( $ipchecklist as $k => $iptoresolve )
{
// gethostbyname: It a VERY SLOW function. We really need to cache the resolved ip list
$ip = gethostbyname($iptoresolve);
if ($ip != "") $iplist[$c] = $ip;
$c++;
}
file_put_contents($filename, implode(";", $iplist));
}
if (in_array($_SERVER['REMOTE_ADDR'], $iplist)) // Check if the client ip is allowed
$isipallowed = true;
if (isset($_SESSION)) $_SESSION['isipallowed'] = $isipallowed;
return $isipallowed;
}
Для лучшей надежности вы можете заменить $_ SERVER ['REMOTE_ADDR'] для get_ip_address(), которую @Pekka упомянул в post как "этот вопрос о щедрости"
Ответ 7
Как сравнить $_SERVER['SERVER_ADDR'] === $_SERVER['REMOTE_ADDR']
, чтобы определить, находится ли клиент на том же компьютере, что и сервер?
Ответ 8
Извините, но все эти ответы кажутся мне ужасными. Я бы предложил перефразировать вопрос, потому что в каком-то смысле все машины являются "локальными".
Вопрос должен быть; Как запустить разные пути кода в зависимости от того, на какой машине он выполняется.
На мой взгляд, самый простой способ - это создать файл с именем DEVMACHINE или что угодно, а затем просто проверить
file_exists ( 'DevMachine')
Не забудьте исключить этот файл при загрузке в среду живого хостинга!
Это решение не зависит от конфигурации сети, оно не может быть подделано и позволяет легко переключаться между "live-code" и "dev-code".
Ответ 9
Я нашел легкий ответ.
Поскольку все локальные диски имеют C: или D: или F:... и т.д.
Просто определите, есть ли второй символ:
if ( substr_compare(getcwd(),":",1,1) == 0)
{
echo '<script type="text/javascript">alert(" The working dir is at the local computer ")</script>';
$client_or_server = 'client';
}
else
{
echo '<script type="text/javascript">alert(" The working dir is at the server ")</script>';
$client_or_server = 'server';
}