了解ACL---通配符掩码

news/2024/7/8 1:33:14

学习ACL,搞懂ACL就不能不搞定wildcard mask,通配符掩码。说简单点,通配符掩码就是0为绝对匹配,必须严格匹配才行,而1为任意,从某种意义上讲,如果一个8位上有一个1字符,那也只有两种方式,0或者1,但是如果进行组合,那么方式就多了。
举例说明吧。
一般我们在应用上都是进行地址块的匹配,怎么讲呢?就是说:
1)对某个A B C类网进行匹配或者教通配符屏蔽
2)对某个子网应用ACL。
3)对特定主机应用ACL
4)对任意主机或者网络应用ACL
5)特殊情况的匹配
差不多就是以上五种情况,下面一一说明。
1)对某个有类网络进行ACL的通配符屏蔽。
这种情况很好解释。
例如:A类:10.0.0.0 0.255.255.255
先写成二进制形式: 00001010.00000000.00000000.00000000
00000000.11111111.111111111.11111111
可以看出,第一个字节需要严格匹配,也就是说必须为10.,后面的任意匹配。
得到的网络为10...*
如果我把这个改一下呢?10.0.0.0 0.0.3.255
同样写成二进制形式:00001010.00000000.00000000.00000000
00000000.00000000.00000011.111111111
前两个字节严格匹配为10.0,后面的同上题一个思路,0就严格匹配,1就任意。
在这里,后10个比特可以任意匹配,我们通过计算可以得到合适的结果:
10.0.0.*
10.0.1.*
10.0.2.*
10.0.3.*
这四个子网

2)
对某个子网应用ACL
还是举例说明,以C类网络192…168.1.0/24为例进行子网划分。
我们引入地址块的思想进行解释会好理解一些。因为子网一般都是以地址块形式存在的。
地址块为128,192.168.1.128 0.0.0.127
地址块为64,192.168.1.0 0.0.0.63
地址块为32,192.168.1.0 0.0.0.31
地址块为16,192.168.1.0 0.0.0.15
地址块为8,192.168.1.0 0.0.0.7
地址块为4,192.168.1.0 0.0.0.3
地址块为2,192.168.1.0 0.0.0.1

3)对特定主机应用ACL
通配符需要全匹配,例如:182.168.12.4 0.0.0.0
还有一种表示方法:host 182.168.12.4
Host在这里是关键字,用来代替0.0.0.0 ,用于源地址和目的地址字段。

4)对任意主机或者网络应用ACL
这是任意匹配的情况,主机任意,通配符任意匹配:0.0.0.0 255.255.255.255,同时这里也有简写——any

5)比较特殊的情况。
用我的话说这种情况是不按规则出牌的情况,也是比较有趣的。
我不想让某个子网或者是某个有类网被通配符屏蔽,我仅仅是想让部分主机被屏蔽,不过这部分主机也应该是有规律的,要不管理人员肯定得折腾疯。哈哈。
仅举两例以供说明:
随便写一个,计算出屏蔽了哪些网络。
随便写一个 192.168.1.23 0.0.0.5
怎么?傻眼了?这就是不按规则出牌的情况,CCNA自学指南里面肯定说了,不能从11.0或者12.0等网络开始,非得是2的次幂才行。对此规矩我们不予理睬,还是使用最为原始的办法进行一个一个匹配。
写成二进制形式:11000000.10101000.00000001.00010111
00000000.00000000.00000000.00000101
接下来就是匹配计算了。前三个字节毫无疑问,严格匹配。最后一个字节逢0匹配,逢1任意。
00010111
00000101 000101
如上的公式,我们看到有星号的位置是可以任意匹配的,这样我们就可以算出:
①00010010——18

②00010011——19

③00010110——21

④00010111——23

这样就很明显了,得到的结果就是192.168.1.18
192.68.1.19
192.168.1.21
192.168.1.23 都被0.0.0.5这个通配符掩码给屏蔽了。
怎样,这个不按规则出牌的通配符掩码是不是也愚弄了你一次?

备注:只要严格按照0——严格匹配,1——任意配置的原则不管什么反掩码都是纸老虎。
写第二个,我需要匹配一个网络里面奇数IP的主机或者偶数IP的主机(或者的路由过滤中需要奇数网络)
还是看例子:
192.168.1.1
192.168.1.2
192.168.1.3
192.168.1.4
192.168.1.5
192168.1.6
192.168.1.7
192.168.1.9
……………
192.168.1.254

思路都是一样的,条条道路通罗马,这里条条道路通配符
我还是要写成二进制形式
前面的三个字节就省略了,只写后面的一个字节的:
00000001
00000010
00000011
00000100
00000101
00000110
00000111
…………
看出规律了么? 什么?没有啊,仔细瞧瞧么!奇数IP的最后一位都是1,而偶数IP的最后一位都是0。这就是规律啊。
那么怎么写呢?这个就比较简单了吧,奇数IP的:192.168.1.1 0.0.0.254 ;偶数IP的呢——192.168.1.2 0.0.0.254

如上就是我对ACL的理解,有说错的,做错的,还望大家指正,所谓三人行必有我师,你有什么更好的办法别忘记跟帖。

ACL主要难点是在通配符的计算,如有这么一道题:
已知子网,求通配符掩码。
例:允许199.172.5.0/24
199.172.10.0/24
199.172.13.0/24
199.172.14.0/24网段访问路由器。要求写出ACL来,但只能用两条ACL代替。

先将这四个数换成二进制:
5.0

0 1 0 1
10.0

1 0 1 0
13.0

1 1 0 1
14.0

1 1 1 0
观察可以看到5.0和13.0
10.0和14.0有共同点。
2.
将不相同的部分用Z表示
5.0和13.0

Z 1 0 1
10.0和14.0

1 Z 1 0
3.
将Z换成1,数字换成0。可以得出:
5.0和13.0

Z 1 0 1
------------ 1 0 0 0
10.0和14.0

1 Z 1 0
------------ 0 1 0 0
4.
最后将二进制换成十进制:
5.0和13.0

Z 1 0 1
------------ 1 0 0 0
-------- 8
10.0和14.0

1 Z 1 0
------------ 0 1 0 0
-------- 4
最后得出:
access-list 10 permit 199.172.5.0 0.0.8.0
access-list 11 permit 199.172.10.0 0.0.4.0


http://www.niftyadmin.cn/n/3842498.html

相关文章

phpExcel输出xls文档在LINUX下显示乱码的解决办法

最近在做一些游戏报表的系统,主要是对excel的读取和处理操作。 之前在自己的机器上做开发的时候,没有出现乱码的情况, 即使是我布置到服务器上,导入,导出excel都没有出现乱码的情况 后来在一位同事的机器上装了下&…

TableStore多元索引,大数据查询的利器

随着互联网发展的深入,互联网开始下沉到各行各业进行互联网改造,比如进入网约车、出租车行业的滴滴,将出租车行业互联网化,改造之前,出租车的分布、订单轨迹、人流热度等交通数据都是直接废弃导致无法利用起来。改造之…

[LeetCode 129] - 根节点到叶子节点数字求和(Sum Root to Leaf Numbers)

问题 给定一个节点取值只包含数字0-9的二叉树,每条根节点至叶子节点的路径都可以表示一个数字。 例如,根至叶子路径1->2->3表示数字123。 求所有根至叶子数字的和。 例如, 1 / \ 2 3 根至叶子路径1->2表示数字12 根至叶子路径…

【转载】软件工程师如何修炼数据科学

此文为转载,原文地址:http://www.rcasts.com/2012/12/software-engineers-guide-to-getting.html,另外,需要说明的是,学习方法是因人而异的,仁者见仁,智者见智,取精去糟。 很多软件攻…

集成实现Dynamics CRM 2011编程系列(55):Dynamics CRM 集成开发简述

废话就不多说了,开始。。。 对于一款企业级的CRM系统在实际的使用过程中不与外界停止交换是不可能的。在博文《Dynamics CRM 2011编程系列(55):Dynamics CRM 集成开辟简述 》中,我就Dynamics CRM的集成开辟概念做了总结…

【MVVM】- Avalon 数组操作

2019独角兽企业重金招聘Python工程师标准>>> avalon 对象、对象数组、数组基本操作 界面 <body ms-controller"test"> <ul> <li ms-repeat"object">{{$key}}-->{{$val}}</li> </ul><br> <button ms-…

【STM32-V6】STM32F429BIT6开发板开源, 丰富软件资源, 强劲硬件配置, 配套400多实例, 9套手册持续更新中2019-08-04...

淘宝购买地址&#xff1a;淘宝购买链接 从2016年1月份发布至今&#xff0c;软件资料更新过27次&#xff0c;详情看帖子二楼。当前标准库最新版本V2.2&#xff0c;HAL库最新版本V0.8 安富莱微信公共平台&#xff0c;欢迎大家关注&#xff08;打造高质量公众号&#xff09; 新版用…

Spring Cloud云架构-Restful 基础架构

对于 Rest 基础架构实现处理是 SpringCloud 核心所在&#xff0c;其基本操作形式在 SpringBoot 之中已经有了明确的讲解&#xff0c;那么本次为 了清晰可见&#xff0c;创建一套新的微服务架构&#xff1a;部门微服务&#xff08;Dept&#xff09;。愿意了解源码的朋友直接求求…