IP白名单的实现(PHP)
有些项目可能会用到一个IP地址的白名单黑名单之类的验证。
比如,只有IP地址在白名单中,才可以访问该系统。
那么此时,白名单的维护,一般是一个文件,里边是一些IP地址(每行一个IP),当然也有的可能是用数据库记录白名单。
当然,即使放在数据库中记录(方便管理),也可以在后台根据数据库生成IP白名单的配置文件,每次更新白名单时,都根据数据库数据,重新写一下白名单的配置文件。
这里,假设白名单的IP地址是存储在一个文件中:while_ips.conf
一般常见的两种情况:一种是白名单文件中的所有IP都是完整的,另一种是有的IP是有范围的(带.*)
一、每一个IP都是完整的IP
127.0.0.0
192.168.1.1
192.168.1.2
192.168.1.30
123.200.20.200
123.101.21.201
以上假设就是IP白名单。
此时的思路是,从文件中读取所有IP地址写入一个数组,每行就是一个元素。
然后判断当前IP是否在这个数组中。这样就实现了这个IP是不是在白名单的验证。
这种实现,比较简单。
function white_ips($file)
{
$a = [];
if (is_file($file)) {// 判断是不是文件
$f = fopen($file, 'r');// 只读的方式打开文件
while (!feof($f)) {// 判断你是否在文件尾,不是文件尾则循环
$s = fgets($f);// 每次读出一行
$s = preg_replace('/\s*/', '', $s);// 先过滤掉多余的空格和空白
if (substr($s, 0, 1) != '#' && $s != '') {// 如果不是注释行,或者空行
$a[] = $s;// 记录有效数据
}
}
fclose($f);
}
return $a;
}
$file是IP白名单文件的存储位置和文件名,其中会过滤掉注释的IP,同时也会过滤掉多余的空白和换行。避免意外出错。
$arr = getWhiteIps('white_ips.conf');
$ip = '192.168.1.1';
$allow = 0;
if (in_array($ip, $arr)) {
$allow = 1;
}
echo $allow;
通过这样调用和判断,就可以知道当前的IP是否在白名单了。
二、第二种情况是白名单配置文件中是有范围的
127.*.*.*
10.*.*.*
192.168.*. *
192.168.1.1
123.200.20.200
123.101.21.201
210.10.22.*
210.123.135.*
#30.11.22.33
#119.123.2.15
以上是假设IP白名单的文件内容
此时的思路是,从文件中读取所有IP地址写入一个数组,每行就是一个元素。
然后通过循环的方式,将当前IP和数组中的每一条数据进行比较(匹配),如果匹配上则白名单,否则不是。
此时因为有范围,所以不能使用in_array这种简单的判断了。需要使用正则来判断。
读取白名单配置文件的代码不变,改变判断方法即可。
function checkIp($ip, $rule)
{
$rule_regexp = str_replace('.*', 'a', $rule);//将.*临时替换成别的符号(.和*都是正则中有特殊含义的符号)
$rule_regexp = preg_quote($rule_regexp, '/');//向规则字符串中增加转义,避免字符串中有其他特殊字符影响正则匹配,非必要语句本例可以忽略
$rule_regexp = str_replace('a','\.\d{1,3}', $rule_regexp);//将临时符号替换成正则表达式
if(preg_match('/^' . $rule_regexp . '$/', $ip)){
return 1;//匹配
}else{
return 0;//不匹配
}
} $arr = getWhiteIps('white_ips.conf');
$ip = '192.168.1.';
$allow = 0;
foreach ($arr as $rule) {
if(checkIp($ip, $rule)){
$allow = 1;//找到一个排配则标记白名单,然后结束循环
break;
}
}
echo $allow;
这种有范围的验证,稍微复杂一点,需要逐一比对判断。利用正则匹配IP后,结束循环。
IP白名单的实现(PHP)的更多相关文章
- Windows Azure Web Site (14) Azure Web Site IP白名单
<Windows Azure Platform 系列文章目录> 我们知道,在Azure Cloud Service和Virtual Machine,可以通过Endpoint ACL (Ac ...
- 利用CentOS系统IPtables防火墙添加网站IP白名单
参考博文: 利用CentOS系统IPtables防火墙添加360网站卫士节点IP白名单 centos6.5添加白名单如下: 在防火墙 配置文件中加入白名单 ip -A INPUT -s 183.13 ...
- 解决微信公众平台IP白名单
微信公众平台,作为自媒体的旗舰级产品,越来越多的人已经投入它的怀抱.正如它的广告词所说:再小的个体,也有品牌 好吧,闲话不多说,今天要说的是它的IP白名单机制. 我们现在安装的大部分的电信的家庭级别的 ...
- 微信公众平台宣布增加接口IP白名单提高安全性
微信公众平台目前已经发布通知在平台接口调用上为了提高安全性需要添加IP白名单并仅允许白名单IP调用. 目前微信公众平台面向开发者主要提供的开发者ID和开发者密钥,在调用时ID和密钥通过检验即可进行调用 ...
- 如何为ASP.NET Core设置客户端IP白名单验证
原文链接:Client IP safelist for ASP.NET Core 作者:Damien Bowden and Tom Dykstra 译者:Lamond Lu 本篇博文中展示了如何在AS ...
- 算法题:实现一个IP白名单过滤器
最近看到一则招聘的JD,附了一个算法题的链接,原题如下: 请实现一个IP白名单过滤算法,实现以下接口 boolean addWhiteIpAddress(String ip); boolean ...
- IP白名单
一.什么是IP白名单 公众平台后台新增了IP白名单功能.通过开发者ID及密码调用获取access_token接口时,需要设置访问来源IP为白名单. IP白名单是指一组IP列表,只有该列表中的IP地址的 ...
- IP白名单添加了当前IP,获取access_token时依然报出错误码40164的坑
开发公众号网页时,想要调用微信API接口,令人无奈的是,想要调用各接口都需使用access_token,于是,获取access_token的征途开始了…… 1.开发者基本配置 (1) 公众平台官网登录 ...
- 对actuator的管理端点进行ip白名单限制(springBoot添加filter)
在我们的SpringCloud应用中,我们会引入actuator来进行管理和监控我们的应用 常见的有:http://www.cnblogs.com/yangzhilong/p/8378152.html ...
随机推荐
- 五子棋棋盘布局 table和ul哪个好
想要在页面布局以上棋盘,可以用ul li 布局,但却有明显的缺点: 1.两行两列:ul li 下面如果再放li 会出错,只能是放其他的,比如div. 或者放li *行*列: 但是这样有两个明显缺陷: ...
- curl HTTP Header
对于"User-Agent", "Cookie", "Host"这类标准的HTTP头部字段,通常会有另外一种设置方法.curl命令提供了 ...
- TS的一些小东西
首先介绍下泛型的三种方法,函数声明,函数表达式,箭头函数 function Interview2<T>(name:T):T{ return name } let mn=function&l ...
- js设计模式(五)---观察者模式
概述: 观察者模式也叫 “ 发布-订阅 " 模式 , 发布者发布信息是不需要考虑订阅者是谁?添加订阅者的时候也不需要通知发布者. 应用: 最经典的就是: DOM事件 开发过程中我们常用自定义 ...
- Python学习之旅(十)
Python基础知识(9):函数(Ⅰ) Python中函数的定义:是逻辑结构和过程化的一种编程方法 定义方法: def test(x): #def:定义函数的关键字 test:函数名 x:形参,也可以 ...
- [No000018D]Vim快速注释/取消注释多行的几种方法-Vim使用技巧(2)
在使用Vim进行编程时,经常遇到需要快速注释或取消注释多行代码的场景,Vim教程网根据已有的教程介绍,总结了三种快速注释/取消注释多行代码的方法. 一.使用Vim可视化模式快速注释/取消注释多行 在V ...
- 补齐-Django之Model操作
http://www.cnblogs.com/wupeiqi/articles/6216618.html
- 计算机组成原理——主存与cache的映射关系
全相联映像: 特点:指主存的一个字块能够映像到整个Cache的不论什么一个字块中.这样的映射方法比較灵活,cache的利用率高.但地址转换速度慢,且须要採用某种置换算法将cache中的内容调入调出,实 ...
- jQuery 学习笔记(4)(文本值相关方法、操控CSS方法、位置和尺寸方法)
1.文本值相关方法 .html() == .innerHTML $("div").html("<span> ...</span>") / ...
- Mac开发工具汇总
1: Json Parser Mac版 http://www.pc6.com/mac/180470.html