单消息队列完成客户服务器进程之间的双向通信

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

哈尔滨理工大学《UNIX程序设计》

课程设计报告

题目:单消息队列完成客户/服务器进程之间的双向通信院系:计算机科学与技术学院网络工程系

班级学号:

姓名:

指导教师:郭锦兰

成绩:

2013年12月23日

第1章绪论 ..................................................................................................- 1 -

1.1 选题内容 .........................................................................................- 1 -

1.2 相关技术 .........................................................................................- 1 - 第2章系统设计 ..........................................................................................- 1 -

2.1系统介绍 .........................................................................................- 2 -

2.2实现原理 ..........................................................................................- 3 -

2.3主要问题的解决方法及关键技术 (5)

2.4 流程图 (6)

第3章系统实现 (7)

3.1客户端截图 (7)

3.2服务器端截图 (8)

结论 (9)

附录 (10)

附录A 核心程序代码 (10)

绪论

1.1选题内容

单消息队列完成客户/服务器进程之间的双向通信

1.2相关技术

随着对通信双方安全性的要求越来越高,对能使通信安全的机制需求更加迫切,UNIX下在消息队列中嵌入加密解密算法无疑适应了潮流。UNIX为进程提供了丰富的交流方式,其中公开的交流方式有信号量、消息队列、共享内存,有名管道和文件等。采用消息队列作为通信渠道可以弥补这些缺陷:

1.消息队列是一种FIFO的队列性结构,可以保证先送的数据先到达,后

送的数据后到达,避免的插队现象。

2.消息队列将输出的信息进行了打包处理,这样就可以保证以每个消息

为单位进行接收了。

3.消息队列还可以对数据分类,更可以对不同分类的数据采取不同的方

式操作,这更加灵活,安全性更高。

所以,利用消息队列实现客户服务器之间的加密通信是一种很安全的方式,研究单消息队列完成客户服务器之间的加密通信业显得很迫切和必要。

系统设计

2.1系统介绍

本单消息队列完成客户/服务器之间的双向通信是基于消息队列的客户/服务器的通信,对通信数据信息进行有效的加密解密,实现客户/服务器之间的双向安全通信。根据需求分析,将整个系统模块化,分为客户端和服务器端两大部分:客户端将数据加密并传输到服务端;服务器端接受数据并解密输出。

2.2 流程图如下:

2.3实现原理

1. 建立或返回消息队列描述符

进程可用系统调用msgget来建立或返回消息队列的描述符。该系统调用的语法格式为:

int msgget(key,msgflg)

key_t key;

int msgflg;

其中,key是消息队列的名字;msgflg是用户设置的标志。如果IPC_CREAT 表示系统无以key命名的消息队列,则建立消息队列标识符;若已存在,则返回消息队列描述符msgid。

对于系统调用,核心将搜索消息队列头标数组,确定是否有指定关键字的消息队列。若无,核心将分配一新的队列结构,并返回给用户一个消息队列描述符;否则,它只是检查消息队列的许可权之后便返回。

2.消息的发送

进程可用megsnd( )系统调用来发送一个消息,并将它链入消息队列的尾部。该系统调用的语法格式如下:

int msgsnd(msgid,msgp,msgsz,msgflg)

int msgid;

struct msgbuf * msgp;

int msgsz,msgflg;

其中,msgid是由msgget返回的消息队列描述符;msgp指向包含这条消息的结构,该结构由如下两个成员组成:

struct msgbuf

{

long mtype; /* 消息类型 */

char mtext[ ]; /* 消息的文本 */

}

msgsz是mtext的字节长度;msgflg规定了当无内存空间来存储消息时,进程等待还是立即返回。

对于msgsnd( )系统调用,核心检查消息队列描述符和许可权是否合法;

消息长度是否超过系统规定的长度,若过长,进程睡眠等待出现足够大的空间,通过检查后,核心为消息分配消息数据区,并将消息从用户空间拷贝到消息数据区,分配消息首部,将它链入该消息队列的尾部,在消息首部填写消息类型,大小以及指向消息数据区的指针,还有修改消息队列的头标中的数据。然后唤醒在等待消息到来的队列中睡眠的进程。

3. 消息的接收

进程可用msgrcv( )系统调用,从消息队列中读一条消息,语法格式为:int msgrcv(msgid,msgp,msgsz,msgtyp,msgflg)

int msgid,msgsz,msgflg;

struct msgbuf * msgp;

long msgtyp;

其中,msgid,msgp,msgsz,msgflg与msgsnd相似,msgtype是规定用户想读的消息类型。

对于msgrcv( )系统调用是先由核心检查消息队列标识符和许可权,接着根据msgtyp分三种情况处理。

(1) msgtyp=0,核心寻找消息队列中的第一个消息,并将它返回给调用进程;

(2)msgtyp为正整数,核心返回给类型的第一个消息;

(3)msgtyp为负整数,核心应在其类型值小于或等于msgtyp绝对值的所有消息中,选择类型最低的第一消息返回。

如果所返回的消息的大小等于或小于用户请求,核心便将消息正文拷贝到用户区,再从队列中删除该消息,并唤醒睡眠的发送进程;如果消息比用户要求的大,则系统返回错误信息。

4.客户端发送数据的加密

考虑到数据由ASCII码经过编程组成,通过对字符串的每个字符的ASCII 码进行加密便显得基础且高效。因此,对于客户端进程进行加密,服务器端进行解密并回传。加密通过对单个字符的ASCII码操作实现。

5.客户端发送数据的加密

数据加密函数如下:

void encode(char *buf){

long i ;

相关文档
最新文档