博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何使用Cisco命令阻止访问特定网站
阅读量:5948 次
发布时间:2019-06-19

本文共 2536 字,大约阅读时间需要 8 分钟。

如何使用Cisco命令阻止访问特定网站 

--------------------------------------------------------------------------------

我最近收到一个读者的电子邮件,他希望知道如何使用Cicso IOS来屏蔽某个特定网站。他是这样写的:“我有一台Cisco 2600,平时一般 用它作为互联网服务器。现在我希望可以屏蔽某些特定网站,我该怎么做呢?” 

  这不是一个很困难的任务——只要您知道Cisco IOS是如何工作的。这里我将指导您如何进行这项工作,并告诉您使用这种方式应当注意些什么 。 

  步骤1:配置一个DNS服务器

  假设我们打算屏蔽一个名为
的网站。我们并不知道该网站的具体IP地址,而且我们也不想知道。没问题——Cisco IOS会自己 把地址找出来并填上它。 

  要做到这一点,我们需要至少在路由器上配置一台DNS服务器。若想配置一台DNS服务器,应使用ip name-server命令。下面是个例子: 

  Router(config)# ip name-server 1.1.1.1 2.2.2.2 

  本例中,我们配置了一个主DNS服务器1.1.1.1,以及一个备用DNS服务器2.2.2.2,以便路由器对域名进行解析。这不会影响路由器的任何流量 。当我们需要对某个域名进行Ping服务时,路由器将使用这些DNS服务器。以下是具体示例: 

  Router# ping 

  Translating "www.techrepublic.com"...domain server (1.1.1.1) [OK] 

  Type escape sequence to abort.

  Sending 5, 100-byte ICMP Echos to 216.239.113.101, timeout is 2 seconds:

  !!!!!

  Success rate is 100 percent (5/5), round-trip min/avg/max = 1/1/4 ms

  Router# 

  在上述例子中,路由器使用了我们指定的域名服务器地址(1.1.1.1)来尝试解析域名。它成功的将域名
解析为对应的IP ——216.239.113.101。 

  如果我们不曾指定DNS服务器,那么路由器很可能会返回下述这些反馈: 

  Translating "www.techrepublic.com"...domain server (255.255.255.255)

  % Unrecognized host or address, or protocol not running.

  (不认识的主机或地址,或可能协议未运行) 

  步骤2:建立ACL

  想真正阻止访问某个网站,我们必须建立一个存取控制列表(access control list,简称ACL)来具体定义我们想阻止什么。下面是个例子: 

  Router(config)# access-list 101 deny tcp any host 
 eq www

  Translating "www.badsite.com"...domain server (1.1.1.1) [OK]

  Router(config)# access-list 101 permit tcp any any eq www

  ! to allow all other web traffic 

  这个ACL拒绝了所有对特定网站
的访问。在阻止访问该网站的同时,它允许所有人访问其他任意网站。 

  最后,由于ACL的隐含禁止,除WWW外所有的其他通信将全部被禁止。 

  如果您想知道到底是哪些IP地址在试图访问被阻止的网站,可以通过使用LOG关键字,记录相关信息。下面是个例子。 

  Router(config)# access-list 101 deny tcp any host 
 eq www log

步骤3:避免“遗漏”

  有一点需要注意。在我们输入了上述ACL的第一行之后,留意路由器是如何使用DNS服务器来解析域名的。然后它会用解析域名所得的IP地址替 换掉ACL中的主机名。我们来仔细看看配置: 

  Router# sh run | inc access-list 101

  access-list 101 deny tcp any host 66.116.109.62 eq www 

  这是个很好的功能,但是可能由于几个原因导致出现问题。首先,该IP仅仅是DNS服务器响应的第一个IP。如果这是个大型网站,有多台服务器 (比如一个搜索引擎),而ACL却仅仅包含了DNS首先响应的第一个IP——您将不得不手工屏蔽其余的IP地址。下面是个示例: 

  C:\> nslookup 

  Server: DNSSERVER

  Address: 1.1.1.1

  Non-authoritative answer:

  Name: 

  Addresses: 64.233.167.104, 64.233.167.147, 64.233.167.99

  Aliases: 
 

  其次,如果被禁止的网页服务器更改了IP地址,ACL中的地址并不会跟随变化。您必须对ACL进行人为更新。 

  步骤4:实施ACL

  仅仅创建了ACL并不意味着路由器就用上了它——我们还必须对ACL进行实施。下面,假设我们要建立一个ACL,以阻止内部局域网访问外部的广 域网(比如Internet)。因此我们应当用ACL的源地址过滤,而不是目标地址的过滤。 

  同样,基于设计的目的,我们需要在路由器的Out方向实施这个ACL。下面是示例。 

  Router(config)# int serial 0/0

  Router(config-if)# ip access-group 101 ou

本文转自loveme2351CTO博客,原文链接:http://blog.51cto.com/loveme23/9168 ,如需转载请自行联系原作者

你可能感兴趣的文章
C++/C学习笔记(九)
查看>>
ASP.net MVC 中Security.FormsAuthentication验证用户的状态(匿名|已登录)
查看>>
《C++ Primer》 Part III(Classes and Data Abstraction)
查看>>
FriendlyUrls——在ASP.NET Web表单中使用更友好的URL
查看>>
【javascript】字符串对象常用 api
查看>>
对PostgreSQL中 index only scan 的初步理解
查看>>
poj 2337 Catenyms
查看>>
第46周星期二
查看>>
hdu1231-最大连续子序列
查看>>
TMG阵列部署选择
查看>>
Repeater 控件 当数据源没有数据的时候显示 暂无数据 的两种方式
查看>>
大型网站的架构设计图分享-转
查看>>
9.15游戏化体验的原则初探
查看>>
(function(){...}())与(function(){...})()
查看>>
css实现气泡框效果
查看>>
【原创】已知四个坐标点求其两条直线交点坐标
查看>>
request 路径随笔
查看>>
.NET基础之自定义泛型
查看>>
HTML5 Canvas 实现的9个 Loading 效果
查看>>
java.lang.NoClassDefFoundError: org/apache/avro/ipc/Responder
查看>>