mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-11 13:58:54 +00:00
Fix for private IPs via HTTP_FOR.. + spoofing of it ... note that getenv doesn't apparently work in ISAPI mode so will only report REMOTE_ADDR
git-svn-id: file:///svn/phpbb/trunk@2314 89ea8834-ac86-4346-8a33-228a782c2dd0
This commit is contained in:
parent
ca1926c032
commit
fc4c0e44f0
1 changed files with 20 additions and 2 deletions
|
@ -142,9 +142,27 @@ $nav_links['author'] = array (
|
||||||
//
|
//
|
||||||
// Obtain and encode users IP
|
// Obtain and encode users IP
|
||||||
//
|
//
|
||||||
if( !empty($HTTP_X_FORWARDED_FOR) )
|
if( getenv('HTTP_X_FORWARDED_FOR') != '' )
|
||||||
{
|
{
|
||||||
$client_ip = ( preg_match("/^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+/", $HTTP_X_FORWARDED_FOR, $ip_list) ) ? $ip_list[0] : $REMOTE_ADDR;
|
$private_ips = array('192.168', '172.16', '10', '224', '240');
|
||||||
|
|
||||||
|
if ( preg_match("/^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+/", getenv('HTTP_X_FORWARDED_FOR'), $ip_list) )
|
||||||
|
{
|
||||||
|
$private_ip = false;
|
||||||
|
for($i = 0; $i < count($private_ips); $i++)
|
||||||
|
{
|
||||||
|
if ( strpos(' ' . $ip_list[0], $private_ips[$i], 1) == 1 )
|
||||||
|
{
|
||||||
|
$private_ip = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$client_ip = ( !$private_ip ) ? $ip_list[0] : $REMOTE_ADDR;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$client_ip = $REMOTE_ADDR;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue