mirror of
https://github.com/project-redbud/FunGame-Server.git
synced 2025-04-22 03:59:36 +08:00
完成Socket封装
This commit is contained in:
parent
edf5fac5ee
commit
3cfe9ceda2
5
Main.cs
5
Main.cs
@ -6,6 +6,7 @@ using System;
|
|||||||
using FunGameServer.Sockets;
|
using FunGameServer.Sockets;
|
||||||
using System.Net.WebSockets;
|
using System.Net.WebSockets;
|
||||||
using FunGameServer.Models.Config;
|
using FunGameServer.Models.Config;
|
||||||
|
using FunGameServer.Utils;
|
||||||
|
|
||||||
bool Running = true;
|
bool Running = true;
|
||||||
Socket? ServerSocket = null;
|
Socket? ServerSocket = null;
|
||||||
@ -96,7 +97,7 @@ bool Read(Socket socket)
|
|||||||
int length = socket.Receive(buffer);
|
int length = socket.Receive(buffer);
|
||||||
if (length > 0)
|
if (length > 0)
|
||||||
{
|
{
|
||||||
string msg = Encoding.GetEncoding("unicode").GetString(buffer, 0, length);
|
string msg = Config.DEFAULT_ENCODING.GetString(buffer, 0, length);
|
||||||
Console.WriteLine("收到来自:客户端(玩家ID) -> " + msg);
|
Console.WriteLine("收到来自:客户端(玩家ID) -> " + msg);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -110,7 +111,7 @@ bool Send(Socket socket)
|
|||||||
// 发送消息给客户端
|
// 发送消息给客户端
|
||||||
string msg = ">> 已连接至服务器 -> [ " + host + " ] 连接成功";
|
string msg = ">> 已连接至服务器 -> [ " + host + " ] 连接成功";
|
||||||
byte[] buffer = new byte[2048];
|
byte[] buffer = new byte[2048];
|
||||||
buffer = Encoding.GetEncoding("unicode").GetBytes(msg);
|
buffer = Config.DEFAULT_ENCODING.GetBytes(SocketHelper.MakeMessage((int)SocketEnums.SendType.CheckLogin, msg));
|
||||||
if (socket.Send(buffer) > 0)
|
if (socket.Send(buffer) > 0)
|
||||||
{
|
{
|
||||||
Console.WriteLine("发送给:客户端 <- " + msg);
|
Console.WriteLine("发送给:客户端 <- " + msg);
|
||||||
|
@ -16,7 +16,7 @@ namespace FunGameServer.Models.Config
|
|||||||
public static int CONNECTING_PLAYERS = 0; // 正在连接的玩家数量
|
public static int CONNECTING_PLAYERS = 0; // 正在连接的玩家数量
|
||||||
public static string SERVER_IPADRESS = "127.0.0.1"; // 默认IP地址
|
public static string SERVER_IPADRESS = "127.0.0.1"; // 默认IP地址
|
||||||
public static int SERVER_PORT = 22222; // 默认端口
|
public static int SERVER_PORT = 22222; // 默认端口
|
||||||
public static string DEFAULT_ENCODING = "unicode"; // 默认传输字符集
|
public static Encoding DEFAULT_ENCODING = Encoding.UTF8; // 默认传输字符集
|
||||||
public static int MAX_CONNECTFAILED = 5; // 最大连接失败次数
|
public static int MAX_CONNECTFAILED = 5; // 最大连接失败次数
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -10,18 +10,26 @@ namespace FunGameServer.Models.Config
|
|||||||
{
|
{
|
||||||
public enum SendType
|
public enum SendType
|
||||||
{
|
{
|
||||||
Login = 1,
|
GetNotice = 1,
|
||||||
CheckLogin = 2,
|
Login = 2,
|
||||||
Logout = 3,
|
CheckLogin = 3,
|
||||||
HeartBeat = 4,
|
Logout = 4,
|
||||||
|
HeartBeat = 5
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ReadType
|
public enum ReadType
|
||||||
{
|
{
|
||||||
Login = 1,
|
GetNotice = 1,
|
||||||
CheckLogin = 2,
|
Login = 2,
|
||||||
Logout = 3,
|
CheckLogin = 3,
|
||||||
HeartBeat = 4,
|
Logout = 4,
|
||||||
|
HeartBeat = 5
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static string SENDTYPE_GetNotice = "GetNotice";
|
||||||
|
public static string SENDTYPE_Login = "Login";
|
||||||
|
public static string SENDTYPE_CheckLogin = "CheckLogin";
|
||||||
|
public static string SENDTYPE_Logout = "Logout";
|
||||||
|
public static string SENDTYPE_HeartBeat = "HeartBeat";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@ using System.Net.Sockets;
|
|||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Data.SqlTypes;
|
using System.Data.SqlTypes;
|
||||||
|
using FunGameServer.Utils;
|
||||||
|
|
||||||
namespace FunGameServer.Sockets
|
namespace FunGameServer.Sockets
|
||||||
{
|
{
|
||||||
@ -32,14 +33,14 @@ namespace FunGameServer.Sockets
|
|||||||
int length = socket.Receive(buffer);
|
int length = socket.Receive(buffer);
|
||||||
if (length > 0)
|
if (length > 0)
|
||||||
{
|
{
|
||||||
string msg = Encoding.GetEncoding(Config.DEFAULT_ENCODING).GetString(buffer, 0, length);
|
string msg = Config.DEFAULT_ENCODING.GetString(buffer, 0, length);
|
||||||
int type = GetType(msg);
|
int type = SocketHelper.GetType(msg);
|
||||||
msg = GetMessage(msg);
|
msg = SocketHelper.GetMessage(msg);
|
||||||
Console.Write("收到来自:客户端(" + type + ") -> " + msg);
|
Console.WriteLine("收到来自:客户端(" + type + ") -> " + msg);
|
||||||
buffer = new byte[2048];
|
|
||||||
length = socket.Receive(buffer);
|
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
|
case (int)SocketEnums.ReadType.GetNotice:
|
||||||
|
break;
|
||||||
case (int)SocketEnums.ReadType.Login:
|
case (int)SocketEnums.ReadType.Login:
|
||||||
break;
|
break;
|
||||||
case (int)SocketEnums.ReadType.CheckLogin:
|
case (int)SocketEnums.ReadType.CheckLogin:
|
||||||
@ -49,9 +50,7 @@ namespace FunGameServer.Sockets
|
|||||||
case (int)SocketEnums.ReadType.HeartBeat:
|
case (int)SocketEnums.ReadType.HeartBeat:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (Send(socket, type, msg))
|
return Send(socket, type, msg);
|
||||||
return true;
|
|
||||||
throw new Exception();
|
|
||||||
}
|
}
|
||||||
throw new Exception();
|
throw new Exception();
|
||||||
}
|
}
|
||||||
@ -67,9 +66,8 @@ namespace FunGameServer.Sockets
|
|||||||
// 发送消息给客户端
|
// 发送消息给客户端
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
string send = MakeMessage(type, msg);
|
|
||||||
byte[] buffer = new byte[2048];
|
byte[] buffer = new byte[2048];
|
||||||
buffer = Encoding.GetEncoding(Config.DEFAULT_ENCODING).GetBytes(Convert.ToString(send));
|
buffer = Config.DEFAULT_ENCODING.GetBytes(Convert.ToString(SocketHelper.MakeMessage(type, msg)));
|
||||||
if (socket.Send(buffer) > 0)
|
if (socket.Send(buffer) > 0)
|
||||||
{
|
{
|
||||||
Console.WriteLine("发送给:客户端(" + type + ") <- " + msg);
|
Console.WriteLine("发送给:客户端(" + type + ") <- " + msg);
|
||||||
@ -84,21 +82,6 @@ namespace FunGameServer.Sockets
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private int GetType(string msg)
|
|
||||||
{
|
|
||||||
return Convert.ToInt32(msg[..(msg.IndexOf(';') - 1)]);
|
|
||||||
}
|
|
||||||
|
|
||||||
private string GetMessage(string msg)
|
|
||||||
{
|
|
||||||
return msg.Substring(msg.IndexOf(';') + 1, msg.Length - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
private string MakeMessage(int type, string msg)
|
|
||||||
{
|
|
||||||
return type + ";" + msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Start()
|
public void Start()
|
||||||
{
|
{
|
||||||
Task StreamReader = Task.Factory.StartNew(() =>
|
Task StreamReader = Task.Factory.StartNew(() =>
|
||||||
@ -114,17 +97,19 @@ namespace FunGameServer.Sockets
|
|||||||
while (Running)
|
while (Running)
|
||||||
{
|
{
|
||||||
if (Socket != null)
|
if (Socket != null)
|
||||||
|
{
|
||||||
if (!Read(Socket))
|
if (!Read(Socket))
|
||||||
{
|
{
|
||||||
FailedTimes++;
|
FailedTimes++;
|
||||||
if (FailedTimes >= Config.MAX_CONNECTFAILED)
|
if (FailedTimes >= Config.MAX_CONNECTFAILED)
|
||||||
{
|
{
|
||||||
Console.WriteLine("ERROR: Too Many Faileds.");
|
Console.WriteLine("ERROR: Too Many Faileds.");
|
||||||
Console.WriteLine("DONE: StringStream is Closed.");
|
Console.WriteLine("DONE: StreamReader is Closed.");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (FailedTimes - 1 >= 0) FailedTimes--;
|
else if (FailedTimes - 1 >= 0) FailedTimes--;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Console.WriteLine("ERROR: Socket is Closed.");
|
Console.WriteLine("ERROR: Socket is Closed.");
|
||||||
|
31
Utils/SocketHelper.cs
Normal file
31
Utils/SocketHelper.cs
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace FunGameServer.Utils
|
||||||
|
{
|
||||||
|
public class SocketHelper
|
||||||
|
{
|
||||||
|
public static int GetType(string msg)
|
||||||
|
{
|
||||||
|
int index = msg.IndexOf(';') - 1;
|
||||||
|
if (index > 0)
|
||||||
|
return Convert.ToInt32(msg[..index]);
|
||||||
|
else
|
||||||
|
return Convert.ToInt32(msg[..1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string GetMessage(string msg)
|
||||||
|
{
|
||||||
|
int index = msg.IndexOf(';') + 1;
|
||||||
|
return msg[index..];
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string MakeMessage(int type, string msg)
|
||||||
|
{
|
||||||
|
return type + ";" + msg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user