四川理工学院
实 验 报 告
实验名称 课程名称
IP地址合法性判断及子网检验
计算机科学与技术
姓名
成绩
班级
学号
日期
2013年1月
地点
计算机学院
一. 实验目的
本设计要求编辑写程序,判断一个ip地址是否合法,并判断该地址是否属于一个给定子网,从而考察读者是否对ip地址概念及其子网划分有非常清楚的认识。
1加深对IP地址及subnet的认识; 2.了解IP地址的划分;
3. 了解subnet的作用和产生因素,subnet的划分; 4. 实际操作编写规则,匹配IP和subnet,加深理解
二. 设计要求
在掌握ip地址表示方法及子网划分方法的基础上,按如下要求完成程序。 1:命令格式:ip_test subnet/mask ip_addr
其中,ip_test为程序名;subnet为子网号,mask是一个数值,代表子网掩码连
续1的个数,ip_addr是要测试的ip地址。 2:判断subnet和ip_addr的合法性。
在判断ip地址合法性时要自行编代码,不要使用任何inet函数。判断时要考虑全
面。
3:判断掩码的合法性。
4:在ip地址合法的前提下,判断ip_addr是否属于子网subnet。
5:输出命令行中的ip是否合法,掩码是否合法,以及ip_addr是否属于子网subnet.
三. 实验环境(软件、硬件及条件)
1.软件
操作系统:Windows xp(Windows NT以上版本皆可)
编程环境:Microsoft Visual Studio 2008(兼容MS VS2005,亦可使用VC6.0等) 编程语言:C++ 测试环境: MS-DOS 2.硬件 现阶段常见PC
四. 实验方法
Part 1 实验原理
我们说过因特网是把全世界的无数个网络连接起来的一个庞大的网间网,每个网络中的
计算机通过其自身的IP地址而被唯一标识的,据此我们也可以设想,在Internet上这个庞大的网间网中,每个网络也有自己的标识符。我们把计算机的IP地址也分成两部分,分别为网络标识和主机标识。同一个物理网络上的所有主机都用同一个网络标识,网络上的一个主机(包括网络上工作站、服务器和路由器等)都有一个主机标识与其对应IP地址的4个字节划分为2个部分,一部分用以标明具体的网络段,即网络标识;另一部分用以标明具体的节点,即主机标识,也就是说某个网络中的特定的计算机号码。另一方面,只有在一个网络号下的计算机之间才能\直接\互通,不同网络号的计算机要通过网关(Gateway)才能互通。但这样的划分在某些情况下显得并十分不灵活。为此IP网络还允许划分成更小的网络,称为子网(Subnet),这样就产生了子网掩码
1. IP的寻址规则 (1).ip分类规则
a、 网络地址必须唯一。
b、 网络标识不能以数字127开头。在A类地址的第一位为0,数字127保留给内部回送函数。 B类地址的前两位为10;C类地址的前三位为110;D类地址的前四位为 1110;E类地址的前五位为 11110。
c、 网络标识的第一个字节不能为255。数字255作为广播地址。
d、 网络标识的第一个字节不能为“0”,“0”表示该地址是本地主机,不能传送。 e、不合法的IP地址类型: 123..2.1 123.23$.2.1 123.2345.2.1 123.23.45.1
2.主机寻址规则
a、主机标识在同一网络内必须是唯一的。
b、主机标识的各个位不能都为“1”,如果所有位都为“1”,则该机地址是广播地址,而非主机的地址。
c、主机标识的各个位不能都为“0”,如果各个位都为“0”,则表示“只有这个网络”,而这个网络上没有任何主机。
3.确定子网掩码数
用于子网掩码的位数决定于可能的子网数目和每个子网的主机数目。在定义子网掩码前,必须弄清楚本来使用的子网数和主机数目。
定义子网掩码的步骤为:
a、确定哪些组地址归我们使用。比如我们申请到的网络号为 “128.73.a.b”,该网络地址为B类IP地址,网络标识为“128.73”,主机标识为“a.b”。
b、根据我们现在所需的子网数以及将来可能扩充到的子网数,用宿主机的一些位来定义子网掩码。比如我们现在需要12个子网,将来可能需要16个。用第三个字节的前四位确定子网掩码。前四位都置为“1”,即第三个字节为“11110000”,这个数我们暂且称作新的二进制子网掩码。
c、把对应初始网络的各个位都置为“1”,即前两个字节都置为“1”,第四个字节都置为“0”,则子网掩码的间断二进制形式为:“11111111.11111111.11110000.00000000”
d、把这个数转化为间断十进制形式为:“255.255.240.0” 这个数为该网络的子网掩码。
4.IP掩码的标注 A、无子网的标注法
对无子网的IP地址,可写成主机号为0的掩码。如IP地址210.73.140.5,掩码为255.255.255.0,也可以缺省掩码,只写IP地址。
B、有子网的标注法
有子网时,一定要二者配对出现。以C类地址为例。IP地址中的前3个字节表示网络号,后一个字节既表明子网号,又说明主机号,还说明两个IP地址是否属于一个网段。如果属于同一网络区间,这两个地址间的信息交换就不通过路由器。如果不属同一网络区间,也就是子网号不同,两个地址的信息交换就要通过路由器进行。例如:假设maskwe为27,对于IP地址为210.73.140.5的主机来说,其主机标识为00000101,对于IP地址为210.73.140.16的主机来说它的主机标识为00010000,以上两个主机标识的前面三位全是000,说明这两个IP地址在同一个网络区域中,这两台主机在交换信息时不需要通过路由器进行;210.73.60.1的主机标识为00000001,210.73.60.252的主机标识为11111100,这两个主机标识的前面三位000与011不同,说明二者在不同的网络区域,要交换信息需要通过路由器。其子网上主机号各为1和252。
Part 2 具体实现
通过以上的原理,我们就知道了在检验IP地址和子网检验时应该明确的问题,关键的两点就是把输入的IP分解成各段,然后判断子网号,掩码和ip地址的基本格式是否合法,
其次:如果三者的基本格式都合法,才调用断定,ip地址是否为子网成员,的函数。该函数同时判别子网号与掩码是否匹配,子网号为全0或全1,主机号为全0、全1。
1. 实现流程
制定规则分别判断子网号,掩码,ip是否合法
设计数据结构 算法实现 调试 测试 数据分析 2. 编程
本部分的编程的主要目的是算法的实现,主要的方法是C++中字符串处理。 (1)类设计 a.属性
char ip[15]; //用于存放ip地址 char ip_Temp[15]; //用于存放ip地址
char subnet_mask[18]; //用于存放subnet_mask地址 char subnet[18]; //用于存放subnet地址 char subnet_Temp[18]; //用于存放subnet地址 int mask; //用于存放mask(1的个数)
bool maskIsValid; //用于判断的个数是否合适,或是否与subnet匹配
b.方法
构造函数,析构函数:
ipTest(char *,char *); //自定义初始化类函数 ~ipTest(); //析构函数
主判断函数 (即主要的方法):
void AllJudgment(); //判断mask,subnet,ip的合法性问题 bool ipIsValid(char *); //判断ip是否合法 Bool subnetIsValid(char *);
//判断子网号subnet是否合法 //ip,subnet地址中非法字符的判断
bool NoIllegalChar(char *); 工具函数:
void print(); //判断ip是否为子网成员,并输出判断结果
void split(char *,int *); //把单个字符地址转换为十进制数值型地址(含四段) Int toBinary(int a); //十进制int型数据转换为二进制int型数据 char * toString(int *a);
//把二进制int型数据转换为一个整体的二进制字符型数据
bool maskIsMatSubnet(int,char *);//判断mask与subnet是否匹配
(2)主函数
int main(int argc,char *argv[]) 函数 ? 1.获取参数 ? 2.简单判断参数格式(长度) ? 3.若是正常参数,实例化 ipTest类