计算机网络课程设计IP地址的合法性及子网判断_第1页
计算机网络课程设计IP地址的合法性及子网判断_第2页
计算机网络课程设计IP地址的合法性及子网判断_第3页
计算机网络课程设计IP地址的合法性及子网判断_第4页
计算机网络课程设计IP地址的合法性及子网判断_第5页
已阅读5页,还剩15页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、学 号: 0120910680421课 程 设 计课程名称计算机网络论文题目ip地址的合法性及子网判断学 院计算机科学与技术学院专 业软件工程班 级软件0904姓 名朱 鹏指导教师周彩兰20112012学年 第2学期课程设计任务书学生姓名: 朱鹏 专业班级: 软件0904 指导教师: 周彩兰 工作单位: 计算机学院 题目四: ip地址的合法性及子网判断 初始条件:(1)学习相关知识(2)c/c+/vc/vb/java语言(3)pc机一台要求完成的主要任务: (包括课程设计工作量及其技术要求,以及说明书撰写等具体要求)在掌握ip地址表示方法及子网划分的基础上,按如下要求完成程序。1)命令行格式:

2、ip_test subnet/mask ip_addr, ip_test其中为程序名;subnet为子网号;mask是一个数值,代表子网掩码连续1的个数;ip_addr是要测试的ip地址。例如,要测试的ip地址为202.114.16.10,子网号为202.113.16.0,子网掩码为255.255.255.0,则命令行为ip_test 202.113.16.0/24 202.114.16.10(因为255.255.255.0是连续的24个1,所以用24表示)。2)判断subnet和ip_addr的合法性。在判断ip地址合法性时要自行编写代码,不要使用任何inet函数。判断时要考虑全面,比如以下

3、ip地址均不合法:123.2.1 / 123.23$.2.1 / 123.2345.2.1 / 123.23.45.2.13)判断掩码的合法性。4)在ip地址合法的前提下,判断ip_addr是否属于子网subnet。5)输出命令行中的ip是否合法,掩码是否合法(可适当给出不合法的原因)以及ip_addr是否属于子网subnet。时间安排:第一、二天:查阅资料,学习算法第三、四天:编程调试第五天:书写报告指导教师签名: 年 月 日系主任(或责任教师)签名: 年 月 日目录1课程设计的目的和意义42课程设计的内容和要求43课程设计的相关技术53.1 ip地址相关概念和知识的回顾53.2特殊的ip地

4、址形式63.3 子网的划分74 课程设计过程74.1 课程设计流程图74.2 课程设计源代码94.3 运行结果155 课程设计小结166 参考文献171 课程设计的目的和意义通过计算机网络课程设计,让我们学会处理几种常用计算机网络问题的基本处理方法,掌握计算机网络的基本原理,使我们在面对不断变化的技术时,具有跟踪,学习的基础与能力。具体而言,关于“ip地址的合法性及子网判断”课程设计题目的目的是:用c/c+语言编写程序,以判断一个ip地址是否合法,并判断该地址是否属于一个给定的子网.从而能够考察我们对ip地址的概念,各类ip地址的区分以及子网划分的理解和掌握程度.课程设计为我们提供了一个既动手

5、又动脑,独立参加实践的好机会,要求我们将理论知识和实际情况有机地结合起来,锻炼我们的分析问题,解决实际问题的能力,提高我们适应实际,实践的能力;它也要求我们综合运用所学的计算机网络知识来解决有一定难度的问题,从而提高了我们对知识的综合运用能力,加深对知识间的融会贯通和联系的理解。2 课程设计的内容和要求在掌握ip地址的表示方法以及子网划分方法的基础上,并以计算机网络中关于ip地址的相关理论知识为基石,运用c/c+语言按如下要求完成程序。a) 命令行格式:ip_test subnet/mask ip_addr其中,ip_test为程序名;subnet为子网号;mask是一个整型数值,代表子网掩码

6、连续1的个数;ip_addr表示要测试的ip地址。比如说,要测试的ip地址为202.113.16.10,子网号码是202.113.16.0,子网掩码是255.255.255.0,则命令行为ip_test202.113.16.0/24 202.113.16.10。(因为255.255.255.0是连续的24个1,所以用24表示)b) 判断subnet和ip_addr的合法性:在判断ip地址合法性时要自行编写代码,不要使用任何inet函数。判断时要考虑各种情况,全面分析问题。例如以下ip地址均不合法:123.2.1123.23$.2.1123.2345.2.1123.23.45.1c) 判断掩码的

7、合法性:譬如说mask的值为负数或者大与32,这时输入的掩码就不合法。(1) 在ip地址合法,掩码合法以及子网号也合法的前提下,判断ip_addr是否属于subnet。(2) 输出命令行中的ip是否合法,掩码是否合法,子网号码是否合法(可适当给出不合法的原因)以及ip_addr是否属于子网subnet。(3) 还可以判断子网号,主机号全0,全1问题。3 课程设计的相关技术3.1 ip地址相关概念和知识的回顾大型的互连网络中应该有一个全局的地址系统,它能够给连接到互联网的每一台主机或者路由器分配一个唯一的全局地址。tcp/ip协议的网络层使用的地址标识符叫做ip地址,ipv4中ip地址是一个32

8、位的二进制地址。网络中的每一台主机或者路由器至少有一个ip地址,在internet中不允许有两个设备具有相同的ip地址。如果一台主机或者路由器连接到两个或多个物理网络,那么它可以拥有两个或多个ip地址。ip地址采用分层结构,由网络号与主机号两部分组成(如下图所示):网络号主机号ip地址长度为32位,用点分十进制表示,格式为.,每个为8位,每个的值为0255(例如202.113.29.119)。根据不同的取值范围,ip地址可以分为五类,ip地址中的前5位用于标识ip地址的类别,具体的分类规则如下:a类地址的第一位为0。b类地址的前两位为10 .c类地址的前三位为110。d类地址的前四位为1110

9、。e类地址的前五位为11110。五类ip地址的结构如下所示;0网络号(7位)主机号(24位)10网络号(14位)主机号(16位)110网络号(21位)主机号(8位)1110组播地址(28位)11110保留用于课程设计和将来使用a类ip地址结构适合用于有大量主机的大型网络。由于主机号长度为24位,因此每个a类网络的主机ip数理论上为224=16777216。b类ip地址适合用于一些国际性大公司与政府机构等中等大小的组织。由于网络ip长度为14位,因此允许有214=16384个不同的b类网络,实际允许连接16382个网络。c类ip地址适合用于一些小公司与普通的研究机构。3.2 特殊的ip地址形式(

10、1) 直接广播地址a类,b类,c类ip地址中主机号全1的地址称为直接广播地址,用来使路由器将一个分组以广播方式发送给特定网络上的所有主机。直接广播地址只能作为分组中的目的地址。物理网络采用的是点点传输方式,分组广播需要通过软件来实现。网络号主机号全1(2)受限广播地址网络号与主机号的32位全位1的地址为受限广播地址,用来将一个分组以广播方式发送给本网的所有主机。本网的所有主机将接受该分组,路由器则阻挡该分组通过。全1(3) “这个网络上的这台主机”地址全0(4)“这个网络上的特定主机”地址主机或路由器向本网络上的某个特定的主机发送分组,网络号部分为全0,主机号为确定的值。这样的分组被相知在本网

11、络内部。网络号全0主机号(5)回送地址回送地址用于网络软件测试和本地进程见通信。tcp/ip协议规定网络号为127的分组不能出现在任何网络上;主机和路由器不能为该地址广播任何寻址信息。127任意值(通常取1)3.3 子网的划分人们在早期设计与建设arpanet是,没有预料到网络的发展速度如此之快,应用范围如此之广。当时个人计算机与局域网尚未出现。所以,研究者在设计internet地址的编址方案时,主要是针对大型互联的网络结构。设计ip地址的最初目的是希望每个ip得志都能唯一地、确定地识别一个网络与一台主机,但是这种方法同时也存在着两个主要的问题,即ip地址的有效利用率和路由器的工作效率。为了解

12、决这个问题,人们提出了子网(subnet)和超网(supernet)的概念。子网就是一个大的网络划分成几个较小的网络,而每一个小网络都是其自己的地址。超网就是将一个组织所属的几个c类网络合并成为一个更大地址范围的逻辑网络。划分子网实际上就是在ip地址系统中增加一个层次。三级ip地址的表示方法为netid-subnet id-host id。第一级网络号定义了网点的位置;第二级子网号定义了物理子网;第三级主机号定义了主机和路由器到物理网络的连接。三级层次的ip地址,一个ip分组的路由器的过程分为三步:第一步将分组转发给网点,第二步转发给物理子网,第三步转发给确切的主机。当三级层次的ip地址提出后

13、,一个很显示的问题是:如何从一个ip地址提取出子网号。因此,提出了子网掩码(subnet mask)的概念。子网掩码有时也叫做子网掩码。子网掩码表示方法:网络号与子网号置1,主机号置0。如判断某一ip地址是否属于某一子网呢?只需将二进制ip地址与子网掩码按位进行“与”运算。若“与”运算所得值与给定子网地址一致,则说明该ip地址属于给定的子网。4 课程设计过程4.1课程设计流程图nyynnynyny 读取一个字符串是否都是数 字字符 return段数=4? 每段的值是否大于255ipisvalid(subnet)是否为真ip&mask=subnetmask是否在(0,32)范围内 子网号与掩码不

14、匹配 程序结束 输出”掩码非法”调用ipisvalid 函数 输出”ip地址非法”输出”子网非法”yn 程序开始,变量初始化4.2 课程设计源代码#include #include #include #include #include #include #include #include #include #include #pragma comment(lib,ws2_32.lib)class iptest /类结构public:char ip15;char subnetplusmask18;char subnet18;char tempip15;l maskisvalid;int mask

15、;char tempsub18; iptest(char *,char *);iptest();bool noillegalchar(char *); /非法字符的判断bool ipisvalid(char *); /判断ip地址是否合法bool subnetisvalid(char *); /判断子网号是否合法void belong(); /判断ip是否为子网成员print(); void main(int argc,char * argv) /主函数if(argc!=3) /判断参数格式化是否正确couterrorendlformat shoud be:ip_test subnet/mas

16、k ip18) /先判断最简单的错误,长度是否超出cout15)coutip is too long;return;iptest test(argv1,argv2); /实例话iptest类test.print(); /完成相应判别并输出结果iptest:iptest( char* subnetplusmask, char *ip) /构造函数maskisvalid=true;char temp2;int smlen=strlen(subnetplusmask); /把/前的字符复制到subnet字符数组中for( int i=0; isubneti=subnetplusmaski;this-

17、tempsubi=subnetplusmaski;subneti=0;tempsubi=0;if(i=smlen-2) /初始化mask和maskisvslidif(i=smlen-2)temp0=subnetplusmaski+1;if( !isdigit(temp0) )maskisvalid = false;else if( i = smlen-3 ) temp0=subnetplusmaski+1;temp1=subnetplusmaski+2;if( !(isdigit(temp0)&isdigit(temp1) )maskisvalid=false;mask = atoi(temp

18、);if( mask 32)maskisvalid = false;elsemaskisvalid=false;strcpy( this-subnetplusmask, subnetplusmask);strcpy( this-ip, ip );strcpy( this-tempip, ip );iptest:print() /调用判别函数,并输出结果bool subisv=subnetisvalid(tempsub);bool ipisv=ipisvalid(tempip);if(!subisv)coutsubnet is invalid ! endl;elsecoutvalid subne

19、t: subnetendl;if(!maskisvalid)coutmask is invalid!endl;elsecoutvalid mask:maskendl;if(!ipisv)coutip is invalid!endl;elsecoutvalid ip:ipendl;/判断ip是否belong subnetif(subisv&ipisv&maskisvalid)belong();bool iptest:noillegalchar(char *ch) /子函数,判断输入是否含有非数字字符unsigned int i,k=0;for(i=0;istrlen(ch);i+)if(isdi

20、git(*(ch+i)=0)return false;return true;bool iptest:ipisvalid(char * ip) /判别ip地址是否合法char ch= .; char *token,*dot4;int iplen=0;token=strtok(ip,ch); /以.标志将ip字符串按节分开while(token!=null) /循环进行,知道结束dotiplen=token; /将分开的每段赋值给dotiplen+;token= strtok(null,ch);if(iplen!=4)couttempsubendl;return false; /段数不对for(

21、int i=0;i255) /有非法字符或某段值非法return false;return true;bool iptest:subnetisvalid(char* subnet) /判断子网号是否合法if( ! ipisvalid(subnet) /调用判别ip地址合法性的函数return false;return true;/判断ip是否为子网成员,判断子网号与掩码是否匹配,以及子网号、主机号全0全1问题void iptest:belong()int sublen=strlen(subnet);int iplen=strlen(ip);unsigned int iipa,isuba,ima

22、sk;unsigned char suba4,ipa4;char temp3;int i,j,t=0;for(i=0,j=0;isublen;i+) /不用再检错if(subneti != .)tempj+=subneti; /temp数组中放.间的串elsesuba3-t = atoi(temp); /suba数组中放.间的数据j=0;t+;temp0=temp1=temp2=0;suba0 = atoi(temp);temp0=temp1=temp2=0;isuba = *( unsigned int *)suba; /isuba中放subnet中.除外的串对应的数for(i= 0, j=

23、 0, t= 0; iiplen; i+) /不用再检错if(ipi != .)tempj+ = ipi;elseipa3-t = atoi(temp);j=0;t+;temp0=temp1=temp2=0;ipa0 = atoi(temp);iipa = *( unsigned int* )ipa; /iipa中放ip中.除外的串对应的数imask = 0xffffffff;imask=(32-mask); /获取掩码if( ( isuba | imask ) != imask ) /说明sub与mask不匹配cout 子网号与掩码不匹配,error!endl;return;if( ( is

24、uba imask ) = 0 ) /说明子网号全1cout 子网号全1,error!endl;return;if( ( isuba & imask ) = 0 ) /说明子网号全0cout 子网号全0,error!endl;return;if( ( isuba) = (iipa & imask) ) /ip和掩码与,结果和子网号比较if( ( iipa | imask) = imask ) /说明主机号全0cout 主机号全0,error!endl;return;if( ( iipa | imask ) = 0xffffffff ) /说明主机号全1cout 主机号全1,error!endl

25、;return;cout ip belongs to subnetplusmaskendl;return;/ip属于subnetelsecout ip doesnt belong to subnetplusmaskendl;/ip不属于subnet4.3 运行结果(1) 子网号、子网掩码和ip地址均不合法时:(2) 子网号、子网掩码和ip地址均合法,且ip地址属于子网号时:(3) 子网号、子网掩码和ip地址均合法,且ip地址不属于子网号时:(4) 子网号不合法时:(5) 掩码不合法时:(6) ip地址不合法时:5 课程设计小结为期一周的计算机网络课程设计终于圆满结束,我所做的课设题目“ip地址的合法性及子网判断”算是比较简单,但是由于对子网掩码等各种概念

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论