软件水平考试(中级)网络工程师下午(应用技术)试题模拟试卷25

0
收藏   分享
  • 卷面总分:75分
  • 试卷类型:模拟考试
  • 测试费用:免费
  • 答案解析:是
  • 练习次数:12次
  • 作答时间:150分钟
试卷简介
试卷预览
1

阅读以下说明,回答问题1、问题2、问题3和问题4。

短消息是指简短的字符信息,在短消息通信系统里,则指由短消息实体发起,通过移动网络传输到指定目的地址的有限长度的文本信息,近几年,短消息服务得到广泛应用。基于web的短消息服务平台的系统结构如图3所示。Web客户端访问Web Server上的短消息服务平台;短消息收发接口通过CMMP协议于短消息网关通信,网关服务器通过SMMP协议于短消息中心通信,短消息中心通过移动网络收发短消息。网关服务器通常可以采用两种方法:

 (1)采用SP(互联网上的业务提供这)直接与某一个SMSC连接,由SMSC直接通过信令网发送短消息给用户。

 (2)采用短消息网关的方式。当采用第一种方式时,在SP的短消息业务量很大时,全部短消息都与sp直连的SMSC转发,造成该SMSC负荷极大,难以满足业务发展的需要。其次,GSM网的规范做法是由用户归属地的SMSc负责用户短消息的转发,若该SMSC与提供服务的SP没有连接,当用户采用手机点播申请短消息服务时,上行短消息将无法发送到该sp。

 因此,随着短消息业务的发展,并且使用GSM网的规范做法,必须采用第二种方式即通过网关方式,才能将大量SP接入到各地的SMSC上,才能保证接入的一致性即安全性,为用户提供优质服务。在这种方式中,短消息网关作为专业化的信息分配及管理者实现SP与 SMSC之间的交互。

目前,国内短消息服务平台按照接入方式主要可分为哪两种?

1

请阅读以下说明和Socket程序,将应填入(n)处的字句写在对应栏内。

网络应用的基本模型是客户机/服务器模型,这是一个不对称的编程模型,通信的双方扮演不同的角色:客户机和服务器。

 一般发起通信请求的应用程序称为客户软件,该应用程序通过与服务器进程建立连接,发送请求,然后等待服务器返回所请求的,内容。服务器软件一般是指等待接收并处理客户机请求的应用程序,通常由系统执行,等待客户机请求,并且在接收到请求之后,根据请求的内容,向客户机返回合适的内容。

 本题中的程序较为简单,客户机接收用户在键盘上输入的文字内容,服务器将客户机发送来的文字内容直接返回给客户机,在通信过程中服务器方和客户机方都遵守的通信协议如下:

 由客户机首先发送请求,该请求由首部和内容两大部分组成,两个部分各占一行文字,通过行结束符“\n”隔离。

 首部只有一个Length域,用于指定请求的内容部分的长度,首部的结构为:“关键词 Iength”+“”+数值+“\n”。

 内容部分为一行文字,其长度必须与Length域的数值相符例如,客户机的请求为“Length 14\nilello,mybaby!”,服务器接收请求处理后返回文字“Hello,my babv!”。

 [Socket程序]

 服务器主程序部分:

 #include<stdio.h>

  ……/引用头文件部分略>

 #define SERVER_PORT 8080//服务器监听端口号为8080

 #define BACKLOG 5  /连接请求队列长度

 int main(int argc,char *a rgv[]){

 int listenfd,connfd//监听套接字、连接套接字描述符

 struct sockaddr_in servaddr;//服务器监听地址

 listenfd=(1);//创建用于监听的套接字

 if(1istenfd<0){

 fprintf(stderr,"创建套接字错误!")

 exit(1);

 }  //套接字创建失败时打印错误信息

 bzero(&servaddr. sizeof(servadd));//将地址结构置空

 servaddr.sin_family=AF_INET;//设置地址结构遵循TCP/IP协议

 servaddr.sln_addrs_addr=htonl. (2);//设置监听的IP地址为任意合法地址,并将该地址转换为网络字节顺序

 servaddr.sin_port=(3);//设置监听的端口,并转化为网络字节顺序

 if(bind (4)<0){

 fprintf(stderr,”绑定套接字与地址!”);

 exit(1);

 } //将监听地址与用于监听的套接字绑定,绑定失败时打印错误信息

 if(listen(listedfd,BACKlOG)<0){

 fprintf(stderr,“转换套接字为监听套接字!”);

 exit(1);

 } //将用于监听的套接字由普通套接字转化为监听套接字

 for(;;){

 connfd=(5);

 //从监听套接字的连接队列中接收已经完成的连接,并创建新的连接套接字

 if(connfd<0){

 fprintf(Stderr,"接收连接失败!");

 exit(1);

 } //接收失败打印错误信息

 serv_respon(connfd);//运行服务器的处理函数

 close(connfd);//关闭连接套接字}

 dose(listenfd); //关闭监听套接字}

 服务器通信部分:

 #include

 <……//引用头文件部分略>

 Void serv_respon(int sockfd){

 Int nbytes;char bur[1024];

 for(;;){

 nbytes=read_requ(Sockfd,bUr,1024);

 //读出客户机发出的请求,并分析其中的协议结构,获知请求的内容部分的长度,并将内容复制到缓冲区buf中,

 if( (6) )return;//如客户机结束发送就退出

 else if(bytes<0){

 fprintf(Siderr,"读错误情息:%S\n",strerror(errno));

 return;

 }//读请求错误打印错误信息

 if(wnte-all(sockfd,buf,nbytes)<0)

 //将请求中的内容部分反向发送回客户机

 fprintf(siderr,"写错误信息:%s\n",strerror(errno));

 }

 }

 int read_requ(int sockfd,char * buf int size){

 Char inbuf[256];

 int n;int i;

 i=read_line(sockfd,inbUf,256);

 //从套接字接收缓冲区中读出一行数据,该数据为客户请求的首部

 if(1<O)return(i);

 else if(i==0)return(0);

 if(stmcmp(inbu,"",6)==0)

 scanf((7),"%d",&n);//从缓冲区buf中读出长度信息

 else{

 sprintf(bur,"",14);

 return(14);

 }//取出首部Length域中的数值,该数值为内容部分的长度

 return(read-all(sockfd,bur,n));//从接收缓冲区中读出请求的内容部分

 }

 int get-char(int fd,char * ch){

 static int offset=0;

 static int size=0;

 static char buff[1024];

 //声明静态变量,在get_char多次被调用期间,该变量的内存不释放

 for(;size<=0 ||(8);){

 size=read(fd,bur,1024);//一次从套接字缓冲区中读出一个数据块

 if(size<0){

 if(errno==EINTR){

 size=0;

 contine;

 //EINT日表示本次读操作没有成功,但可以继续使用该套接字读出数i

 }else

 return(-1);

  }

 offset=0;//读出数据后,将偏址置为0

 *ch:buf[offset++);//将当前的字符取出,并将偏址移向下一字符

 return(1);

 }

 int read_line(int fd,char * buf,int msxlen){

 int i, n;

 Char ch;

 for(i=0;i<(9)){

 n=get_char(fd,&ch);//取出一个字符

 if(n==1){

 buff[i++]=ch//将字符加入字符串中

 if( (10) )break;

 }else if(n<)return(-1);

 else break;

 }

 buf[i]='\0';

 return(i);

 }