ET---PacketParser3.0学习笔记

本文档介绍了PacketParser3.0与2.0的主要差异,重点在于3.0将包结构封装为类,明确了包体结构,并详细解析了公共常量及构造函数的意义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PacketParser3.0学习笔记(与2.0的差异)

请大家关注我的微博:@NormanLin_BadPixel坏像素


与2.0相比,3.0把包结构封装成了一个类,着就明文规定了包体的结构,不像之前,包体结构是我们心里规定的。

public const int MinSize = 2;
public const int OpcodeIndex = 1;
public const int RpcIdIndex = 3;

这三个常量规定了包体的最小体积,操作符的下标位置,RpcId的小标位置。我们可以看到,操作符还是占有2个字节。

public Packet(int length)
{
    this.Length = 0;
    this.Bytes = new byte[length];
}

注意一下这个构造函数,这个构造函数相当于建立了一个length大小的包但是里面的内容为空的实例。举个例子,就相当于我们先建造了一个可以装length体积水的水桶,这个时候水桶里没有水,所以this.Length = 0。之后,我们可以往这个水桶里装水也就是存数据。

public byte Flag()
{
    return this.Bytes[0];
}

我们知道Opcode是从数据的第二位开始存的,那么第一位存的是什么数据呢?就是这家伙了,不过现在我们并不知道这家伙是干嘛的,不过应该也是用来标识数据包的。我们查看了它的引用,发现在Session3.0里面可以解释它的作用。

其他的跟2.0的没什么区别。

login Executing (default): SELECT `user_id`, `username`, `password`, `nickname`, `phone`, `avatar` FROM `tb_user` AS `tb_user` WHERE `tb_user`.`user_id` = &#39;101&#39; AND `tb_user`.`password` = &#39;123456&#39;; Executing (default): SELECT `product_id`, `remaincount`, `seller_id`, `product_name`, `price`, `stock`, `status`, `img`, `img1`, `img2` FROM `tb_product` AS `tb_product`; Executing (default): SELECT `address_id`, `user_id`, `receiver`, `phone`, `address`, `is_default` FROM `tb_address` AS `tb_address` WHERE `tb_address`.`user_id` = &#39;101&#39;; Executing (default): SELECT `order_id`, `status` FROM `tb_order` AS `tb_order` WHERE `tb_order`.`user_id` = &#39;101&#39; AND `tb_order`.`status` IN (0, 1); 查询订单商品失败: Error at Query.run (E:\Code\Back-TaoBao\node_modules\sequelize\lib\dialects\mysql\query.js:52:25) at E:\Code\Back-TaoBao\node_modules\sequelize\lib\sequelize.js:315:28 at process.processTicksAndRejections (node:internal/process/task_queues:105:5) at async MySQLQueryInterface.select (E:\Code\Back-TaoBao\node_modules\sequelize\lib\dialects\abstract\query-interface.js:407:12) at async tb_order.findAll (E:\Code\Back-TaoBao\node_modules\sequelize\lib\model.js:1140:21) at async E:\Code\Back-TaoBao\router.js\get_order.js:14:20 { name: &#39;SequelizeDatabaseError&#39;, parent: Error: Table &#39;taobao.tb_order&#39; doesn&#39;t exist at Packet.asError (E:\Code\Back-TaoBao\node_modules\mysql2\lib\packets\packet.js:740:17) at Query.execute (E:\Code\Back-TaoBao\node_modules\mysql2\lib\commands\command.js:29:26) at Connection.handlePacket (E:\Code\Back-TaoBao\node_modules\mysql2\lib\base\connection.js:475:34) at PacketParser.onPacket (E:\Code\Back-TaoBao\node_modules\mysql2\lib\base\connection.js:93:12) at PacketParser.executeStart (E:\Code\Back-TaoBao\node_modules\mysql2\lib\packet_parser.js:75:16) at Socket.<anonymous> (E:\Code\Back-TaoBao\node_modules\mysql2\lib\base\connection.js:100:25) at Socket.emit (node:events:518:28) at addChunk (node:internal/streams/readable:561:12) at readableAddChunkPushByteMode (node:internal/streams/readable:512:3) at Readable.push (node:internal/streams/readable:392:5) { code: &#39;ER_NO_SUCH_TABLE&#39;, errno: 1146, sqlState: &#39;42S02&#39;, sqlMessage: "Table &#39;taobao.tb_order&#39; doesn&#39;t exist", sql: "SELECT `order_id`, `status` FROM `tb_order` AS `tb_order` WHERE `tb_order`.`user_id` = &#39;101&#39; AND `tb_order`.`status` IN (0, 1);", parameters: undefined }, original: Error: Table &#39;taobao.tb_order&#39; doesn&#39;t exist at Packet.asError (E:\Code\Back-TaoBao\node_modules\mysql2\lib\packets\packet.js:740:17) at Query.execute (E:\Code\Back-TaoBao\node_modules\mysql2\lib\commands\command.js:29:26) at Connection.handlePacket (E:\Code\Back-TaoBao\node_modules\mysql2\lib\base\connection.js:475:34) at PacketParser.onPacket (E:\Code\Back-TaoBao\node_modules\mysql2\lib\base\connection.js:93:12) at PacketParser.executeStart (E:\Code\Back-TaoBao\node_modules\mysql2\lib\packet_parser.js:75:16) at Socket.<anonymous> (E:\Code\Back-TaoBao\node_modules\mysql2\lib\base\connection.js:100:25) at Socket.emit (node:events:518:28) at addChunk (node:internal/streams/readable:561:12) at readableAddChunkPushByteMode (node:internal/streams/readable:512:3) at Readable.push (node:internal/streams/readable:392:5) { code: &#39;ER_NO_SUCH_TABLE&#39;, errno: 1146, sqlState: &#39;42S02&#39;, sqlMessage: "Table &#39;taobao.tb_order&#39; doesn&#39;t exist", sql: "SELECT `order_id`, `status` FROM `tb_order` AS `tb_order` WHERE `tb_order`.`user_id` = &#39;101&#39; AND `tb_order`.`status` IN (0, 1);", parameters: undefined }, sql: "SELECT `order_id`, `status` FROM `tb_order` AS `tb_order` WHERE `tb_order`.`user_id` = &#39;101&#39; AND `tb_order`.`status` IN (0, 1);", parameters: {} }
最新发布
05-22
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值