近来项目须要做一个客户查询状况体系,当前上位机缺乏效劳功用,因而找到了networkcomms 开源框架,作为项目运用.
最新版networkcomms 下载地点:https://github.com/MarcFletcher/NetworkComms.Net
下载直接vs翻开
新建效劳器端
using MessageContract; using NetworkCommsDotNet; using NetworkCommsDotNet.Connections; using NetworkCommsDotNet.Connections.TCP; using NetworkCommsDotNet.DPSBase; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Net; using System.Text; using System.Windows.Forms; namespace AppServer { public partial class MaiForm : Form { public MaiForm() { InitializeComponent(); } SendReceiveOptions aboveOptions = new SendReceiveOptions(DPSManager.GetDataSerializer<ProtobufSerializer>(), null, null); private void button1_Click(object sender, EventArgs e) { //效劳器最先监听客户端的要求 Connection.StartListening(ConnectionType.TCP, new IPEndPoint(IPAddress.Parse(txtIP.Text), int.Parse(txtPort.Text))); //效劳器最先监听客户端的要求 //IPEndPoint thePoint = new IPEndPoint(IPAddress.Parse(txtIP.Text), int.Parse(txtPort.Text)); //TCPConnection.StartListening(thePoint, false); button1.Text = "监听中"; button1.Enabled = false; //button1.Text = "监听中"; //button1.Enabled = false; //此要领中包括效劳器细致的处置惩罚要领。 StartListening(); } private void StartListening() { //开启日记纪录 //设置日记纪录器 //ILogger logger = new LiteLogger(LiteLogger.LogMode.ConsoleAndLogFile, "ServerLogFile_" + NetworkComms.NetworkIdentifier + ".txt"); //NetworkComms.EnableLogging(logger); //禁用日记纪录 效劳器端正式运用时,赢禁用日记纪录 NetworkComms.DisableLogging(); //效劳器端处置惩罚收到的音讯 //为简朴起见,此示例中我们只处置惩罚字符范例的信息,也返回字符范例的信息。 //处置惩罚的信息能够使自定义类,细致见下一个Demo NetworkComms.AppendGlobalIncomingPacketHandler<LoginContract>("ReqLogin", IncomingLoginRequest); } //处置惩罚某个细致的要求 private void IncomingLoginRequest(PacketHeader header, Connection connection, LoginContract loginContract) { try { string resMsg = ""; //为了简朴,这里不挪用数据库,而是模仿一下登录 if (loginContract.UserID == "1000" && loginContract.PassWord == "123") resMsg = "登录胜利"; else resMsg = "用户名暗码毛病"; //把返回效果写入到左券类中,背面返回给客户端 //ResMsgContract contract = new ResMsgContract(); //contract.Message = resMsg; //connection.SendObject<ResMsgContract>("ResLogin", contract); ResMsgContract contract = new ResMsgContract(); contract.Message = resMsg; connection.SendObject("ResLogin", contract); } catch (Exception ex) { // LogTools.LogException(ex, "IncomingMsgHandle"); } } } }
在别的协助中每每少了这行:致使涌现客户端发送时,范例打包涌现题目. 这行代码是客户端效劳器两头都要加上的,是指定传输体式格局
SendReceiveOptions aboveOptions = new SendReceiveOptions(DPSManager.GetDataSerializer<ProtobufSerializer>(), null, null);
就是这个报错了
一下是客户端
using MessageContract; using NetworkCommsDotNet; using NetworkCommsDotNet.Connections; using NetworkCommsDotNet.Connections.TCP; using NetworkCommsDotNet.DPSBase; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace AppClient { public partial class MainForm : Form { public MainForm() { InitializeComponent(); } //衔接信息对象 public ConnectionInfo connInfo = null; //衔接对象 Connection newTcpConnection; SendReceiveOptions aboveOptions = new SendReceiveOptions(DPSManager.GetDataSerializer<ProtobufSerializer>(), null, null); private void button1_Click(object sender, EventArgs e) { //给衔接信息对象赋值 connInfo = new ConnectionInfo(txtIP.Text, int.Parse(txtPort.Text)); //假如不胜利,会弹出非常信息 newTcpConnection = TCPConnection.GetConnection(connInfo); button1.Enabled = false; button1.Text = "衔接胜利"; } private void btnlogin_Click(object sender, EventArgs e) { //给左券类赋值 LoginContract contract = new LoginContract(txtUserName.Text, txtPassword.Text); //contract.UserID = txtUserName.Text; //contract.PassWord = txtPassword.Text; //向效劳器发送登录信息并猎取登录效果 ResMsgContract resMsg = newTcpConnection.SendReceiveObject<LoginContract, ResMsgContract>("ReqLogin", "ResLogin", 5000, contract); //向效劳器发送登录信息并猎取登录效果 // ResMsgContract resMsg = newTcpConnection.SendReceiveObject<ResMsgContract>("ReqLogin", "ResLogin", 5000, contract); if (resMsg.Message == "登录胜利") { MessageBox.Show("登录胜利"); } else { MessageBox.Show("用户名暗码毛病"); } } } }
左券类
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace MessageContract { [ProtoContract] public class LoginContract { [ProtoMember(1)] public string UserID { get; set; } [ProtoMember(2)] public string PassWord { get; set; } public LoginContract() { } public LoginContract(string userID, string passWord) { this.UserID = userID; this.PassWord = passWord; } } } using ProtoBuf; using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace MessageContract { [ProtoContract] public class ResMsgContract { [ProtoMember(1)] public string Message; public ResMsgContract() { } public ResMsgContract(string message) { this.Message = message; } } }
注重:
运用这个框架要合营谷歌的protobuf 要选好版本.本人没反复测试最高版本,由于在调试登录过程当中涌现别的题目过程当中,也顺改了protobuf 的版本,至今未测试最高版本是不是存在兼容题目.本人胜利的运用的是2.0.0.668
protobuf简介protobuf是google供应的一个开源序列化框架,类似于XML,JSON如许的数据示意言语,其最大的特点是基于二进制,因而比传统的XML示意高效短小
vs nuget增加体式格局
输入
版本挑选本身指定一下,加大项目的左券类里边.这是本身定义传输对象的体式格局.
效果:
以上所述是小编给人人引见的C# networkcomms 3.0完成模仿上岸总结,愿望对人人有所协助,假如人人有任何疑问请给我留言,小编会实时复兴人人的。在此也非常感谢人人对剧本之家网站的支撑!
以上就是C#中networkcomms3.0怎样完成模仿上岸的代码分享(图)的细致内容,更多请关注ki4网别的相干文章!