首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >PHP IP过滤

PHP IP过滤
EN

Stack Overflow用户
提问于 2011-11-10 04:43:50
回答 3查看 6K关注 0票数 20

我希望允许用户根据他们的ip地址过滤他们的登录(这是我将实现的用户首选项中的新设置)。

因此,如果用户使用特定的ip登录并且没有限制,则登录是成功的。

在任何其他情况下,我都是这样想的

如果用户选择他的完整IP,如67.31.85.47,并且他拥有此IP,则登录是好的。如果用户选择67.31.85。*并且具有此IP,则如果用户选择67.31,则登录是好的。如果用户选择67...*并且拥有此IP,则登录是有效的任何其他情况都是无效的

用户最多可以选择5个IP限制。例如:

代码语言:javascript
复制
67.31.*.*
167.77.47.*
62.11.28.28
25.57.*.*
169.*.*.*

我正在修修补补的剥离IP使用爆炸,然后比较所有的限制,他设置。这可能会很慢,因为我必须检查5次*4 (4 = IP在点上爆炸)

有没有更快的方法呢?谢谢

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-11-10 09:05:37

代码语言:javascript
复制
<?php
function testIP($ip) {
    if($ip == '*' || $ip == '*.*.*.*') {
        return TRUE;
    }
    if($_SERVER['REMOTE_ADDR'] == $ip) {
        return TRUE;
    }
    $mask = str_replace('.*', '', $ip);
    return strpos($_SERVER['REMOTE_ADDR'], $mask) === 0;
}

$_SERVER['REMOTE_ADDR'] = '70.69.68.67';

$ip = '1.11.1.*';
echo "Is $ip good: "; var_dump(testIP($ip));
$ip = '2.34.9.1';
echo "Is $ip good: "; var_dump(testIP($ip));
$ip = '70.11.*.*';
echo "Is $ip good: "; var_dump(testIP($ip));
$ip = '70.69.68.*';
echo "Is $ip good: "; var_dump(testIP($ip));
$ip = '70.69.*.*';
echo "Is $ip good: "; var_dump(testIP($ip));
$ip = '70.*.*.*';
echo "Is $ip good: "; var_dump(testIP($ip));
$ip = '*.*.*.*';
echo "Is $ip good: "; var_dump(testIP($ip));
$ip = '*';
echo "Is $ip good: "; var_dump(testIP($ip));

将输出:

代码语言:javascript
复制
Is 1.11.1.* good: bool(false)
Is 2.34.9.1 good: bool(false)
Is 70.11.*.* good: bool(false)
Is 70.69.68.* good: bool(true)
Is 70.69.*.* good: bool(true)
Is 70.*.*.* good: bool(true)
Is *.*.*.* good: bool(true)
Is * good: bool(true)

如果您正在寻找特定的ip (无通配符)检查,您可以使用:

代码语言:javascript
复制
function is_private_ip($ip) {
  return filter_var($ip, FILTER_VALIDATE_IP) != FALSE;
}

var_dump(is_private_ip('82.237.3.3'));var_dump(is_private_ip('748.1234.5.4'));

票数 28
EN

Stack Overflow用户

发布于 2011-11-10 05:02:12

也许这个想法对你有帮助:

代码语言:javascript
复制
<?php
$ip_restrict = "67.31.*.*
167.77.47.*
62.11.28.28
25.57.*.*
169.*.*.*";

$ip_restrict = array_flip(explode("\n", $ip_restrict));
$ip = preg_match("!([0-9]+)\.([0-9]+)\.([0-9]+)\.([0-9]+)!", $_SERVER['REMOTE_ADDR'], $ip_match);


$ip_in_blacklist = false;
$ip_check_1 = $ip_match[1] . '.*.*.*';
$ip_check_2 = $ip_match[1] . '.' . $ip_match[2] . '.*.*';
$ip_check_3 = $ip_match[1] . '.' . $ip_match[2] . '.' . $ip_match[3] . '.*';
$ip_check_4 = $ip_match[1] . '.' . $ip_match[2] . '.' . $ip_match[3] . '.' . $ip_match[4];

if (isset($ip_restrict[$ip_check_1]) || isset($ip_restrict[$ip_check_2]) || isset($ip_restrict[$ip_check_3]) || isset($ip_restrict[$ip_check_4])) {
    $ip_in_blacklist = true;
}

var_dump($ip_in_blacklist);

票数 6
EN

Stack Overflow用户

发布于 2014-03-15 14:46:57

代码语言:javascript
复制
$auth_ip=array();
$client_ip=array();
$client_ip=explode(".", $_SERVER['REMOTE_ADDR']);
$auth_ip=explode("\n", $patner_name_id[0]['client_ip']);
$j=0;
$flag=0;

foreach ($auth_ip as $value) {
    $i=0;
    $value=explode(".", $value);
    foreach ($value as $valueip) {
        if($valueip!="*") { 
            if($valueip!=$client_ip[$i]){
                $flag=1;
                 break;
            }
            $i++;
        }
        else {
            $i++;
            continue;
        }               
    }
}

if($flag==1){
    header("Location:".$default_company);           
    exit;
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8071395

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档