unity学习(25)——客户端与服务器合力完成注册功能(7)逻辑流程彻底解决

在服务器LoginHandler类中:

cs 复制代码
public void login(Session session, SocketModel model)
{
  LoginDTO loginDto = Coding<LoginDTO>.decode(model.Message);
  //MyLog.form.textAdd("用户申请登录" + loginDto.userName + "      " + loginDto.passWord);
  Console.WriteLine(("用户申请登录" + loginDto.userName + "      " + loginDto.passWord));
  string v = BizUtil.account.login(loginDto.userName, loginDto.passWord, session);
  session.write(0, 0, 1, (object) new StringDTO(v));
}

BizUtil.account.login,就认为是把账号密码存入数据库就行了,其实是一个"字典+文件"。

session.write(0, 0, 1, (object) new StringDTO(v));是写客户端发送数据包,数据包的message表示是否注册成功。

此时,结合(24)中所总结的结构。客户端在NetWorkScript 中,先通过ReceiveCallBack将收到的数 据,收到的数据表写到System.Buffer中,Buffer的定义如下:

cs 复制代码
namespace System
{
    public static class Buffer
    {
        public static void BlockCopy(Array src, int srcOffset, Array dst, int dstOffset, int count);
        public static int ByteLength(Array array);
        public static byte GetByte(Array array, int index);
        [CLSCompliant(false)]
        public static void MemoryCopy(void* source, void* destination, long destinationSizeInBytes, long sourceBytesToCopy);
        [CLSCompliant(false)]
        public static void MemoryCopy(void* source, void* destination, ulong destinationSizeInBytes, ulong sourceBytesToCopy);
        public static void SetByte(Array array, int index, byte value);
    }
}

然后是MessageManager利用机制不停调用UpDate,UpDate不断读取 利用 删除第一条消息。

利用是使用OnMessage函数利用的是服务器内部的消息,问题很明显了,就是加入Buffer的 没有转换成消息

OnMessage所处理的消息在,List<SocketModel> list = NetWorkScript.getInstance().getList();

去NetWorkScript中,队列定义如下:

cs 复制代码
private static List<SocketModel> messageList = new List<SocketModel>();

很明显这是个网络包队列,唯一的增加队列元素的方法如下:

cs 复制代码
private void readMessage(byte[] message)//处理所收到的信息
{
    MemoryStream ms = new MemoryStream(message, 0, message.Length);
    ByteArray ba = new ByteArray(ms);//这个模型是自定义的
    SocketModel model = new SocketModel();
    model.type = ba.ReadInt();
    model.area = ba.ReadInt();
    model.command = ba.ReadInt();
    int length= ba.ReadInt();
    if (length>0)
    {
        model.message = ba.ReadUTFBytes((uint)length);
    }
    messageList.Add(model);//这个函数也是自定义的
    Debug.Log("readMessage并加入消息队列");
}

但现在我 客户端已有的代码中没有调用 readMessage,估计是我前面的学习遗漏了,和源代码对比一下。明确到目前为止,客户端只有这一个List,也就是说无论游戏内部的消息,还是服务器发来的数据包,都应该写到这个List中

原代码的NetWorkScript中果然有readMessage的调用,是我之前漏了

修改后的代码如下!

cs 复制代码
private static void ReceiveCallBack( IAsyncResult ar)//回调方法 
{
    try
    {
        int readCount = 0;
        readCount = socket.EndReceive(ar);//ar其实就是传进来的内容
        byte[] temp = new byte[readCount];
        Buffer.BlockCopy(buff, 0, temp, 0, readCount);//从buff到temp
        addMessage(temp);//将收到的包 加入 List!
        Debug.Log("小丑到底是谁:"+readCount);
        Debug.Log("ReceiveCallBack里的buff:" + BitConverter.ToString(buff));
        //再多新建一个
    }
    catch 
    {
        socket.Close();
        Debug.Log("net error");
    }
    socket.BeginReceive(buff, 0, 1024, SocketFlags.None, ReceiveCallBack, buff);//形成闭环
}
private static void addMessage(byte[] message)//处理所收到的信息
{
    MemoryStream ms = new MemoryStream(message, 0, message.Length);
    ByteArray ba = new ByteArray(ms);//这个模型是自定义的
    SocketModel model = new SocketModel();
    model.type = ba.ReadInt();
    model.area = ba.ReadInt();
    model.command = ba.ReadInt();
    int length= ba.ReadInt();
    if (length>0)
    {
        model.message = ba.ReadUTFBytes((uint)length);
    }
    messageList.Add(model);//这个函数也是自定义的
    Debug.Log("readMessage将服务器发来的包,加入List");
}

测试发现,还有一些小问题!

增加输出MessagerManger所收到的内容,一下内容是点击panel中"确定"按钮后自产自销的内容。

紧接着的List内容应该是服务器所返回数据包的内容:

返回的数据包有错,应该是编码问题!

相关推荐
Pythonliu722 分钟前
茴香豆 + Qwen-7B-Chat-Int8
linux·运维·服务器
我是哈哈hh38 分钟前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
郭二哈42 分钟前
C++——模板进阶、继承
java·服务器·c++
Ace'1 小时前
每日一题&&学习笔记
笔记·学习
IM_DALLA1 小时前
【Verilog学习日常】—牛客网刷题—Verilog进阶挑战—VL25
学习·fpga开发·verilog学习
挥剑决浮云 -1 小时前
Linux 之 安装软件、GCC编译器、Linux 操作系统基础
linux·服务器·c语言·c++·经验分享·笔记
丶Darling.1 小时前
LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
数据结构·c++·学习·算法·leetcode·二叉树
立秋67891 小时前
Python的defaultdict详解
服务器·windows·python
Lansonli2 小时前
云原生(四十一) | 阿里云ECS服务器介绍
服务器·阿里云·云原生
john_hjy2 小时前
11. 异步编程
运维·服务器·javascript