C# Socket報(bào)文和端口測(cè)試工具的開發(fā)(提供源碼)
因?yàn)樽约航?jīng)常做Socket開發(fā),經(jīng)常要調(diào)試和維護(hù)多個(gè)服務(wù)器端和客戶端的通信、報(bào)文數(shù)據(jù)等,網(wǎng)上的工具都是功能簡(jiǎn)單,用的不爽,所以一直都想自己寫一個(gè)。
Socket測(cè)試工具
Socket測(cè)試工具源碼
年底不忙了,終于寫了一個(gè),提供給大家使用,源碼可以隨便使用和修改,歡迎多提意見,讓這個(gè)工具更易用,方便Socket編程開發(fā)人魚。主要的功能如下:
1.建立Socket測(cè)試服務(wù)器端和測(cè)試客戶端,并向其他端發(fā)送或接受報(bào)文數(shù)據(jù),支持自動(dòng)發(fā)送和自動(dòng)應(yīng)答,支持UDP和TCP;
2.錄入的IP地址和端口等參數(shù)數(shù)據(jù)進(jìn)行本地XML序列化,下次自動(dòng)打開。(這個(gè)是我需要的,不用每次都錄入各種IP地址端口了);
3.接受或發(fā)送的報(bào)文數(shù)據(jù),可以直接保存在日志文件當(dāng)中,便于離線分析。
4.服務(wù)器端,可以查看接入的各個(gè)連接信息;
5.支持AscII和16進(jìn)制的數(shù)據(jù)發(fā)送和接收顯示。
由于界面要同時(shí)支持TCP和UDP的數(shù)據(jù)通信,所以編寫了兩個(gè)接口IServer和IClient,便于界面和通信層分開。
- public interface IServer
- {
- //初始化
- void Init(string serverIp, int port);
- //從服務(wù)器端給某個(gè)連接發(fā)送數(shù)據(jù)
- void Send(string connId, byte[] data, int length);
- //監(jiān)聽
- int Listen();
- //得到當(dāng)前的連接
- List<IConnection> GetConnectionList();
- //Socket事件
- event ReceivedHandler OnDataReceived;
- event SocketErrorHandler OnSocketError;
- void Close();
- }
為了保存參數(shù)數(shù)據(jù),所以構(gòu)造了一個(gè)SocketInfo類,對(duì)應(yīng)客戶端和服務(wù)器端,然后將這個(gè)集合序列化到XML文件中。
序列化的代碼如下:
- [Serializable]
- public class SocketInfo
- {
- public string Name { get; set; }
- //Server端或客戶端類型
- public string Type { get; set; }
- //16進(jìn)制格式或AscII
- public string Format { get; set; }
- public string ServerIp { get; set; }
- public int Port { get; set; }
- //TCP或UDP
- public string Protocol { get; set; }
- //報(bào)文數(shù)據(jù)
- public string Data {get;set;}
- //是否自動(dòng)發(fā)送或接收數(shù)據(jù)
- public Boolean IsAuto {get;set;}
- public SocketInfo()
- {
- Format = "AscII";
- Protocol = "Tcp";
- Port = 8890;
- ServerIp = "127.0.0.1";
- Data = "請(qǐng)錄入測(cè)試數(shù)據(jù)";
- }
- }
- public class MySerializer
- {
- public static void Serialize<T>(T value, string xmlFileName)
- {
- if (value == null)
- {
- return;
- }
- XmlSerializer serializer = new XmlSerializer(typeof(T));
- XmlWriterSettings settings = new XmlWriterSettings();
- settings.Encoding = new UnicodeEncoding(false, false);
- settings.Indent = false;
- settings.OmitXmlDeclaration = false;
- FileStream fs = new FileStream(xmlFileName, FileMode
- .OpenOrCreate);
- serializer.Serialize(fs, value);
- fs.Close();
- }
- public static T Deserialize<T>(string xmlFileName)
- {
- if (string.IsNullOrEmpty(xmlFileName))
- {
- return default(T);
- }
- XmlSerializer serializer = new XmlSerializer(typeof(T));
- //XmlSerializer serializer = new XmlSerializer(typeof(ArrayList));
- XmlReaderSettings settings = new XmlReaderSettings();
- //settings.
- FileStream fs = null;
- try
- {
- fs = new FileStream(xmlFileName, FileMode.Open);
- // Deserialize the content of the XML file to a Contact array
- // utilizing XMLReader
- XmlReader reader = new XmlTextReader(fs);
- T contacts = (T)serializer.Deserialize(reader);
- return contacts;
- }
- catch (FileNotFoundException)
- {
- // Do nothing if the file does not exists
- }
- finally
- {
- if (fs != null) fs.Close();
- }
- return default(T);
- }
- }
客戶端的報(bào)文和服務(wù)器端的報(bào)文數(shù)據(jù)存放在Client.log和Server.log兩個(gè)文件當(dāng)中.主要是借助了Log4net的配置實(shí)現(xiàn)的.
- <log4net>
- <root>
- <level value="ALL" />
- <appender-ref ref="RollingFileAppender" />
- </root>
- <appender name="ClientLogFileAppender" type="log4net.Appender.RollingFileAppender">
- <param name="File" value="client.log"/>
- <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
- <appendToFile value="true" />
- <rollingStyle value="Size" />
- <maxSizeRollBackups value="3" />
- <maximumFileSize value="2MB" />
- <staticLogFileName value="true" />
- <layout type="log4net.Layout.PatternLayout">
- <conversionPattern value="記錄時(shí)間:%date 日志:%message%newline" />
- </layout>
- </appender>
- <logger name="SocketTool.ClientForm">
- <level value="DEBUG" />
- <appender-ref ref="ClientLogFileAppender" />
- </logger>
- <appender name="ServerLogFileAppender" type="log4net.Appender.RollingFileAppender">
- <param name="File" value="server.log"/>
- <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
- <appendToFile value="true" />
- <rollingStyle value="Size" />
- <maxSizeRollBackups value="3" />
- <maximumFileSize value="2MB" />
- <staticLogFileName value="true" />
- <layout type="log4net.Layout.PatternLayout">
- <conversionPattern value="記錄時(shí)間:%date 日志:%message%newline" />
- </layout>
- </appender>
- <logger name="SocketTool.ServerForm">
- <level value="DEBUG" />
- <appender-ref ref="ServerLogFileAppender" />
- </logger>
- </log4net>
原文鏈接:http://www.ltmonitor.com/blog/?p=285