ESFramework网络通信框架介绍之(1)――网络通信消息协议接口IContract

简介: 一.ESFramework网络通信框架与字节流        通过网络通信的系统之间(如客户端与服务端的通信)要想正常交互,它们必须有“共同的语言”,这种语言就是消息协议。遵守消息协议的消息才能被我们的系统所理解。

一.ESFramework网络通信框架与字节流   

    通过网络通信的系统之间(如客户端与服务端的通信)要想正常交互,它们必须有共同的语言,这种语言就是消息协议。遵守消息协议的消息才能被我们的系统所理解。
   
我们知道,消息在网路上传输的是字节流,而我们主流的面向对象系统中处理的却是对象,如何将从网络上接收到的字节流转化为对象,又如何将对象转化为字节流以便通过网络传递给其他系统,这便是IContract接口定义的内容:

   

 1     ///   <summary>
 2       ///  IContract 用于抽象通信协议格式的基础接口。
 3       ///   </summary>
 4       public   interface  IContract
 5      {
 6           void     FillMyself( byte [] data , int  offset) ;  // 将流解析为对象
 7           int       GetStreamLength() ;
 8 
 9           byte [] ToStream() ;               // 将对象转化为流
10           void    ToStream( byte [] buff , int  offset);        
11      }    

    IContract接口中的各个成员的意思非常的清楚,含有offset参数的重载ToStream方法(第10行)可以将转化的结果流写到指定的buff中,这个方法是必须的,否则就会遇到很多需要拷贝缓冲区的操作,这将严重的损害运行的效率。

   
很多朋友一定想到了,.NET中将对象转化为字节流或将流转化为对象的最方便的方式就是使用序列化,是的,如果各个通信的系统都是基于.NET平台创建的,当然没有问题,这种情况下,使用.NET Remoting可能会更好(使用Remoting可以完全省略对消息协议的关心,因为Remoting已经帮你打点好了一切)。但是更多的情况是,相互通信的系统是异构的。比如,服务端是.NET平台,而客户端却是PDAC++写的程序,遇到这种情形,.NET的序列化、Remoting就无能为力了,我们必须自己手动打理一切。你也许会说,可以使用WebService?呵呵,好了,
ESFramework网络通信框架主要关注的是构建基于TcpUdp网络系统,至于什么情况下,该使用WebService还是该直接在更低层的TCP/UDP上构建系统的问题,还是留待读者自己去思考吧:)


   
如果不能使用.NET序列化,那么常用的是什么方法来完成字节流《=》消息对象的转换了,即IContract.FillMyselfIContract.ToStream的实现方式是什么?一个字节一个字节的处理。比如,我们消息协议中规定,接收到的字节流的前四个字节是一个使用UTF8编码的字符串“@@@@”,那么,我们解析时,就用UTF8来将接收到的前4个字节解析为字符串“@@@@”。接下来的4个字节是一个整数,那么你可以使用BitConverter类来将这四个字节解析为一个整数,......如此,一直将所有字节流解析完毕,生成一个完整的消息对象。至于字节流中的第几个字节放什么内容,那是你的构建应用时必须定义好的--消息协议。所有的消息协议都实现IContract接口。在此基础之上,应用系统才可以在不了解协议内部细节的情况下,对所有的消息进行统一的处理(这就是多态的应用啊),如此才有可能实现系统运行中动态加载功能插件的能力。

  二.ESFramework网络通信框架与 IContract接口

   ESFramework网络通信框架,它不关注你具体应用中的具体消息协议,它只关注IContract接口,这样ESFramework网络通信框架才可以在不同的应用中复用。如果要使ESFramework框架帮助我们构建应用时更加容易,ESFramework就需要把我们应用中更多共性提取出来,那么它必须标准化更多的东西,IContract只是其中的一个。接下来的文章中你会看到NetMessage的引入,系统之间通过网络交互的消息都可以表示成NetMessage,并且NetMessage游走于系统内部的各处理器、钩子Hook之间,正是由于这种前后一致性,使得NetMessage成为ESFramework的核心要素之一,关于NetMessage的具体介绍请留意下篇文章:
    ESFramework网络通信框架介绍之(2)――网络通信消息NetMessage

    转到:ESFramework可复用的网络通信框架(序)

版权声明:本文为博主原创文章,未经博主允许不得转载。 

 

目录
相关文章
|
17天前
|
网络协议 Linux
在Linux中,管理和配置网络接口
在Linux中管理网络接口涉及多个命令,如`ifconfig`(在新版本中被`ip`取代)、`ip`(用于网络设备配置)、`nmcli`(NetworkManager的CLI工具)、`nmtui`(文本界面配置)、`route/ip route`(处理路由表)、`netstat/ss`(显示网络状态)和`hostnamectl/systemctl`(主机名和服务管理)。这些命令帮助用户启动接口、设置IP地址、查看连接和路由信息。不同发行版可能有差异,建议参考相应文档。
19 4
|
1天前
|
缓存 网络协议 网络架构
【计算机网络】第三章 数据链路层(MAC地址 IP地址 ARP协议)
【计算机网络】第三章 数据链路层(MAC地址 IP地址 ARP协议)
|
4天前
|
Ubuntu 网络协议 Linux
Linux(20) Ubuntu 20.04 网络接口自动切换路由配置
Linux(20) Ubuntu 20.04 网络接口自动切换路由配置
27 0
|
9天前
|
网络协议 Java API
深度剖析:Java网络编程中的TCP/IP与HTTP协议实践
【4月更文挑战第17天】Java网络编程重在TCP/IP和HTTP协议的应用。TCP提供可靠数据传输,通过Socket和ServerSocket实现;HTTP用于Web服务,常借助HttpURLConnection或Apache HttpClient。两者结合,构成网络服务基础。Java有多种高级API和框架(如Netty、Spring Boot)简化开发,助力高效、高并发的网络通信。
|
10天前
|
存储 网络协议 安全
15.网络协议-Radius协议
15.网络协议-Radius协议
|
10天前
|
存储 网络协议 网络安全
14.网络协议-邮件协议
14.网络协议-邮件协议
|
14天前
|
存储 JSON 前端开发
网络原理(4)HTTP协议(下)
网络原理(4)HTTP协议
26 0
|
14天前
|
网络协议 Java API
Python网络编程基础(Socket编程)Twisted框架简介
【4月更文挑战第12天】在网络编程的实践中,除了使用基本的Socket API之外,还有许多高级的网络编程库可以帮助我们更高效地构建复杂和健壮的网络应用。这些库通常提供了异步IO、事件驱动、协议实现等高级功能,使得开发者能够专注于业务逻辑的实现,而不用过多关注底层的网络细节。
|
17天前
|
存储 网络协议 Linux
|
17天前
|
安全 SDN 数据中心