feat : 에코 서버 / 클라이언트 기능 추가 작업

This commit is contained in:
qornwh1
2026-03-01 01:05:14 +09:00
parent 30457819b1
commit 97f6187f5d
13 changed files with 255 additions and 133 deletions

View File

@@ -1,3 +1,5 @@
using System;
using System.IO;
using ProtoBuf;
using Serilog;

View File

@@ -4,6 +4,7 @@
<TargetFramework>net9.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
<LangVersion>13</LangVersion>
</PropertyGroup>
<ItemGroup>

View File

@@ -1,5 +1,8 @@
using System;
using System.Collections.Generic;
using System.Net;
using System.Net.Sockets;
using System.Threading;
using LiteNetLib;
using LiteNetLib.Utils;
using Serilog;
@@ -122,6 +125,13 @@ public abstract class ServerBase : INetEventListener
{
(ushort type, ushort size, byte[] payload) = PacketSerializer.Deserialize(data);
// 0이라면 에코 서버 테스트용 따로 처리
if (type == 0)
{
HandleEcho(peer, payload);
return;
}
// Auth 패킷은 베이스에서 처리 (raw 8-byte long, protobuf 불필요)
if (type == (ushort)PacketType.Auth)
{
@@ -167,16 +177,33 @@ public abstract class ServerBase : INetEventListener
}
}
// Echo 서버 테스트
private void HandleEcho(NetPeer peer, byte[] payload)
{
// if (payload.Length < sizeof(long))
// {
// Log.Warning("[Server] Echo 페이로드 크기 오류 PeerId={Id}", peer.Id);
// peer.Disconnect();
// return;
// }
// 세션에 넣지는 않는다.
NetDataReader reader = new NetDataReader(payload);
Log.Debug("[Echo] : addr={Addr}, str={Str}", peer.Address, reader.GetString());
SendTo(peer, payload);
}
// ─── Auth 처리 (내부) ────────────────────────────────────────────────
private void HandleAuth(NetPeer peer, byte[] payload)
{
if (payload.Length < sizeof(long))
{
Log.Warning("[Server] Auth 페이로드 크기 오류 PeerId={Id}", peer.Id);
peer.Disconnect();
return;
}
// if (payload.Length < sizeof(long))
// {
// Log.Warning("[Server] Auth 페이로드 크기 오류 PeerId={Id}", peer.Id);
// peer.Disconnect();
// return;
// }
long hashKey = BitConverter.ToInt64(payload, 0);

View File

@@ -1,4 +1,6 @@
namespace ServerLib.Service;
using System.Collections.Generic;
namespace ServerLib.Service;
public class SessionManager
{