Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2553498
  • 博文数量: 709
  • 博客积分: 12251
  • 博客等级: 上将
  • 技术积分: 7905
  • 用 户 组: 普通用户
  • 注册时间: 2005-07-17 00:00
个人简介

实现有价值的IT服务

文章存档

2012年(7)

2011年(147)

2009年(3)

2008年(5)

2007年(74)

2006年(431)

2005年(42)

分类: IT职场

2005-07-18 21:33:53


二.实现包过滤


    1.相关的Tcp/Ip知识
    2Iptables语法
    3.使用举例

二.使用用户空间命令iptables实现包过滤

1.相关的Tcp/Ip知识
     1
)建立TCP连接(3次握手)

      C:Client     (S:Server)                            

        |              |                   

       1|-----(SYN) ----à |                    

        |              |                     

        | ß-(SYN/ACK)-| 2                    

        |              |                    

        |-----(ACK) -à  | 3                    

        |              |                    

        |              |                    

 

 

     2)结束TCP连接(4次握手)

      C:Client     (S:Server)                            

        |                       |                   

      1 |-----(ACK/FIN) --------à   |                    

        |                       |                    

        | ß-( ACK)---------------------|  2                    

        |                       |                    

        |ß--(ACK/FIN)-------------- |  3                    

        |                       |                    

        |-----(ACK)------ --------à  |  4                   

        |                       |                      

                                           

 

其中还可能涉及到:
SYN(
同步)ACK(应答)FIN(结束)RST(重设)URG(紧急)PSH(强迫推送)NONE

    3
)无效的TCP标志
ALL(
SYN,ACK,FIN,RST,URG,PSH)
SYN/FIN/PSH
SYN/FIN/RST

SYN/FIN/RST/PSH

FIN

None


    4)ICMP
类型

 


2
Iptables语法

 

iptables -ADC 来指定链的规则,-A添加 -D删除 -C 修改
iptables - [RI] chain rule num rule-specification[option]
iptables - RI 通过规则的顺序指定

iptables -D chain rule num[option]
删除指定规则
iptables -[LFZ] [chain][option]
iptables -LFZ 链名 [选项]

iptables -[NX] chain
-NX 指定链

iptables -P chain target[options]
指定链的默认目标

iptables -E old-chain-name new-chain-name
-E
旧的链名 新的链名
用新的链名取代旧的链名
说明
Iptalbes
是用来设置、维护和检查Linux内核的IP包过滤规则的。
可以定义不同的表,每个表都包含几个内部的链,也能包含用户定义的链。每个链都是一个规则列表,对对应的包进行匹配:每条规则指定应当如何处理与之相匹配的包。这被称作'target'(目标),也可以跳向同一个表内的用户定义的链。

TARGETS
防火墙的规则指定所检查包的特征,和目标。如果包不匹配,将送往该链中下一条规则检查;如果匹配,那么下一条规则由目标值确定.该目标值可以是用户定义的链名,或是某个专用值,ACCEPT[通过], DROP[删除], QUEUE[排队], 或者 RETURN[返回]
ACCEPT
表示让这个包通过。DROP表示将这个包丢弃。QUEUE表示把这个包传递到用户空间。RETURN表示停止这条链的匹配,到前一个链的规则重新开始。如果到达了一个内建的链(的末端),或者遇到内建链的规则是RETURN,包的命运将由链准则指定的目标决定。

TABLES
当前有三个表(哪个表是当前表取决于内核配置选项和当前模块)
-t table
这个选项指定命令要操作的匹配包的表。如果内核被配置为自动加载模块,这时若模块没有加载,(系统)将尝试(为该表)加载适合的模块。这些表如下:filter,这是默认的表,包含了内建的链INPUT(处理进入的包)、FORWORD(处理通过的包)和OUTPUT(处理本地生成的包)。nat,这个表被查询时表示遇到了产生新的连接的包,由三个内建的链构成:PREROUTING (修改到来的包)OUTPUT(修改路由之前本地的包)、POSTROUTING(修改准备出去的包)。mangle 这个表用来对指定的包进行修改。它有两个内建规则:PREROUTING(修改路由之前进入的包)和OUTPUT(修改路由之前本地的包)。
OPTIONS
这些可被iptables识别的选项可以区分不同的种类。

COMMANDS
这些选项指定执行明确的动作:若指令行下没有其他规定,该行只能指定一个选项.对于长格式的命令和选项名,所用字母长度只要保证iptables能从其他选项中区分出该指令就行了。
-A -append
在所选择的链末添加一条或更多规则。当源(地址)或者/ 目的(地址)转换为多个地址时,这条规则会加到所有可能的地址(组合)后面。

-D -delete
从所选链中删除一条或更多规则。这条命令可以有两种方法:可以把被删除规则指定为链中的序号(第一条序号为1),或者指定为要匹配的规则。

-R -replace
从选中的链中取代一条规则。如果源(地址)或者/ 目的(地址)被转换为多地址,该命令会失败。规则序号从1开始。

-I -insert
根据给出的规则序号向所选链中插入一条或更多规则。所以,如果规则序号为1,规则会被插入链的头部。这也是不指定规则序号时的默认方式。

-L -list
显示所选链的所有规则。如果没有选择链,所有链将被显示。也可以和z选项一起使用,这时链会被自动列出和归零。精确输出受其它所给参数影响。

-F -flush
管理员在2009年8月13日编辑了该文章文章。

-->
阅读(1505) | 评论(0) | 转发(0) |
0

上一篇:转:Oracle常用脚本:

下一篇:Grep 用法(引)

给主人留下些什么吧!~~