用Cisco IDS的Recovery CD,在一臺X86嘅PC上打造一臺IDS,詳細見全文。
硬件准备:
PC一台,需求如下
主版:440BX主板最好,当然其他也没问题,至少是支持440BX,VIA686a;AMD芯片应该也可以;
CPU:基本不限,PII 以上均可,当然越高越好,建议600MHz以上主频;至少支持我的Athlon 1.7;
RAM:256M - 4G, 推荐512M以上;
硬盘:普通IDE硬盘就可以,当然几种常见SCSI也是没问题的,另外似乎也支持iSCSI;
網卡:唯一最重要的要求就是这个了,至少需要两块网卡,根据你想制造的型号不同。
注意其中至少一块必须是百兆(EEPro100各型)或千兆(EEPro1000各型)的Intel网卡。芯片组可以是Intel 82557/82558/82559/82550等(可能也支持Broadcom BCM5700)。这块Intel网卡是作为监听卡用的,因此必须插在PCI 1槽上,至少要比第二块卡在PCI上的位置靠前,这样在系统中它会被认为ETH0,而ETH0是系统默认的监听口,必须为Intel网卡。
另一块卡理论上可以是Linux 2.4内核所能支持的任何芯片的网卡,但是我们也推荐使用Intel EEpro100,这样可以省去很多麻烦,避免不必要的错误发生。这块卡在系统中会被认为是ETH1,用作管理和通讯。
配置:
AMD Athlon XP 1700+
1G RAM
160G IDE 或 LSI 160 SCSI (均支持)
默认监听口 ETH0@ PCI1: Intel 82559(EEPro 100 Management+)
默认通讯口 ETH1@ PCI*: Intel 82559(EEPro 100+)
监听口2 ETH2@ PCI*: Intel 82559(EEPro 100+)
无 ETH2@ PCI*: Intel 82559(EEPro 100+)
接下来开始安装CiscoIDS。准备好CiscoIDS的Recovery CD,一切就像安装普通的Redhat Linux一样简单 --其实还更简单一点。 启动界面会给你一个选择,是使用控制台(键盘+显示器)还是串口。当然选控制台,会快得多,在boot:提示符后输入 k 。之后就不用管了,它会完全自动的完成安装。
注意!它可是独占硬盘的,如果你的硬盘上还有其他系统,它会自动格式化整个盘,可不会提示你。
0. 进入单用户模式状态
安装完成后系统会自动重新启动,你可以看见熟悉的GRUB引导菜单,在这里我们进行第一次修改和初始化设置。
选择在菜单的第一项 [ Cisco IDS (2.4.18-5smpbigphys) ]上,按下"e"键进行设置,然后在
[kernel /boot/vmlinuz-2.4.18-5smpbigphys ro root=/dev/hda1 bigphysarea=32768 ]
这一行上(应该是第二行)再按"e",进行编辑,在行尾加上"single",进行单用户模式引导。
修改如下:
kernel /boot/vmlinuz-2.4.18-5smpbigphys ro root=/dev/hda1 bigphysarea=32768 single
然后按"ESC" "b",开始引导。完成之后,会进入Linux的单用户模式Shell下,开始Crack步骤。
我们需要做以下几步工作:
1. 设置root密码
======================================================
# passwd root
[输入两次确认密码]
======================================================
2. 破解IDS设备型号识别
代码:
======================================================
# vi /etc/init.d/ids_functions
编辑 isCPU() 函数一节如下:
======================================================
isCPU(){
# $1 = CPU speed
# MAX_DIFF=4
# PROC=`awk '/^cpu MHz/{ print $4 }' $CPU_INFO_FILE | tail -1 | cut -f1 -d"."`
MAX_DIFF=150
PROC=1260
======================================================
(在MAX_DIFF=4和PROC=`两行前加上 "#" 注释;然后添加 MAX_DIFF=150 和PROC=1260两行)
vi快捷指南:
代码:
vi是Linux下默认的编辑器,作上面修改可以按下列键序:
:输入 /isCPU
-会自动跳转到isCPU()一行
:输入 i
-进入编辑模式
:输入 在MAX_DIFF和PROC二行前加上 # 字符
:输入 MAX_DIFF=150
:输入 PROC=1260
:输入 [ESC]键
:输入 :wq 三个字符,回车
-修改和保存文件
3. 重新启动系统
======================================================
# init 3
======================================================
之后系统会自动检查设备型和配置硬件,在这个过程中系统可能或重新启动数次,直至最后稳定的进入命令提示符状态:
sensor login:
这时可以使用 [ 用户名: cisco 口令: cisco ]进行登录,第一次登录系统会强制要求更改系统默认帐户密码,以及添加一个Service用户。
完成之后,输入 reset 命令,重新启动系统。
4. 再次重启系统时,进行一些其他设置; 引导时使用 0 节的方法,进入单用户模式。然后:
修改ssh配置文件,允许root远程登录,修改/etc/ssh/sshd_config文件,修改如下两行
Port 22
PermitRootLogin yes #(默认为no)
修改grub配置文件/boot/grub/grub.conf ,允许控制台管理;修改如下一行:
kernel /boot/vmlinuz-2.4.18-5smpbigphys ro root=/dev/hda1 bigphysarea=32768 #console=ttyS0,9600
(在console=ttyS0,9600前加 # 号,或删除console=...至行尾)
最后执行下一个步骤,最后一点初始化设置。
5. 进行系统初始化设置
======================================================
# init 3
======================================================
使用cisco用户登录进入系统,然后运行setup命令。
======================================================
# setup
--- System Configuration Dialog ---
At any point you may enter a question mark '?' for help.
User ctrl-c to abort configuration dialog at any prompt.
Default settings are in square brackets '[]'.
Current Configuration: (显示当前配置)
........
Current time: Wed Mar 16 18:06:41 2005
Setup Configuration last modified: Wed Mar 16 16:42:07 2005
Continue with configuration dialog?[yes]: (输入yes继续配置)
Enter host name[sensor]: (输入主机名)
Enter IP address[192.168.0.99]: (输入通讯口IP地址[eth1])
Enter netmask[255.255.255.0]: (子网掩码)
Enter default gateway[192.168.0.254]: (默认网关)
Enter telnet-server status[enabled]: (允许telnet登录)
Enter web-server port[443]: (允许Web管理)
Modify current access list?[no]: yes (编辑访问控制列表,按 [IP_Address 空格 NetMask]格式)
Modify system clock settings?[no]:
[0] Go to the command prompt without saving this config.
[1] Return back to the setup without saving this config.
[2] Save this configuration and exit setup.
Enter your selection[2]: (选择2保存配置)
======================================================
最后,可以reset重启一次,你的系统应该完全伪造成功了。
之后可以用你熟悉的任何管理方式连接上去进行管理,telnet,ssh,串口,或https://访问地址。
如果需要更详细的管理功能,恐怕你得安装CiscoWorks VMS或IDS Manager了。
6. 补充一点设备型号,在这个例子中,我们仿造的系统型号是Cisco IDS4235,其实也可以
修改成其他型号,一个列表如下:
代码:
TYPE CPU RAM NIC XL ACCEL FIBER
4210 567 x1 512 2 - -
4215 845 x1 512 2 - -
4220 598 x1 ? >=2 - -
4230 598 x2 ? 3 - -
4235 1260 x1 ? 3 - -
4250 1260 x2 ? ? - -
4250SX 1260 x2 ? ? - 1
4250XL 1260 x2 ? ? 1 1
XL = XL加速卡
FIBER = 千兆光纤卡
NIC = 网卡
RAM 推荐任意型号都>512M
CPU 表中为CPU标称主频,后面为数量在破解过程中,所关系到的主要设备就是CPU,只要把第二节中PROC=1260的数字改成其他频率,系统就会认为系统TYPE为其他型号,当然CPU数量也是一个次要决定因素,暂时我们就不考虑Crack 双CPU的型号了,虽然理论上可行,但是不确定是否能稳定工作。
另一个因素就是网卡,建议至少配备2块Intel 82559芯片的网卡;当然,多一点也可以。在其他型号的网卡和硬件上系统也可以安装和运行,甚至Vmware里也可以,但是是无法正常抓包工作的,仅仅能做个游戏品罢了。此外,非官方推断,众多Dell服务器上配置的Broadcom BCM 5700网卡可能也是可以工作的。正如PIX OS实际可能也支持BCM 5600/5700一样。
sensor# show version
Application Partition:
Cisco Systems Intrusion Detection Sensor, Version 4.1(1)S47
OS Version 2.4.18-5smpbigphys
Platform: IDS-4250
Sensor up-time is 46 min.
Using 91938816 out of 127279104 bytes of available memory (72% usage)
Using 527M out of 6.3G bytes of available disk space (9% usage)