2025-06-20 17:00:56 +08:00
|
|
|
|
package handler
|
|
|
|
|
|
|
2025-06-23 10:15:22 +08:00
|
|
|
|
import (
|
2025-07-26 02:14:54 +00:00
|
|
|
|
"blazing/common/data/entity"
|
2025-07-25 01:29:03 +00:00
|
|
|
|
"blazing/common/utils/bytearray"
|
2025-07-15 11:24:49 +08:00
|
|
|
|
|
2025-07-14 11:07:13 +08:00
|
|
|
|
"bytes"
|
|
|
|
|
|
"fmt"
|
|
|
|
|
|
"reflect"
|
2025-06-24 22:09:05 +08:00
|
|
|
|
|
2025-07-14 11:07:13 +08:00
|
|
|
|
"github.com/lunixbochs/struc"
|
2025-06-24 22:09:05 +08:00
|
|
|
|
"github.com/panjf2000/gnet/v2"
|
2025-06-23 10:15:22 +08:00
|
|
|
|
)
|
|
|
|
|
|
|
2025-06-20 17:00:56 +08:00
|
|
|
|
// TomeeHeader 结构体字段定义
|
|
|
|
|
|
type TomeeHeader struct {
|
2025-07-15 11:24:49 +08:00
|
|
|
|
Len uint32 `json:"len"`
|
|
|
|
|
|
Version string `json:"version" struc:"[1]byte"`
|
|
|
|
|
|
CMD uint32 `json:"cmdId" struc:"uint32"`
|
|
|
|
|
|
UserID uint32 `json:"userId"`
|
2025-06-24 22:09:05 +08:00
|
|
|
|
//Error uint32 `json:"error" struc:"[0]pad"`
|
|
|
|
|
|
|
|
|
|
|
|
Result uint32 `json:"result"`
|
2025-07-14 11:10:16 +08:00
|
|
|
|
Data []byte `json:"data" struc:"skip"` //组包忽略此字段// struc:"[0]pad"
|
2025-07-25 07:46:31 +00:00
|
|
|
|
//Return []byte `struc:"[0]pad"` //返回记录
|
2025-06-20 17:00:56 +08:00
|
|
|
|
}
|
2025-07-06 19:31:30 +08:00
|
|
|
|
|
|
|
|
|
|
func NewTomeeHeader() *TomeeHeader {
|
|
|
|
|
|
|
|
|
|
|
|
return &TomeeHeader{
|
|
|
|
|
|
// Len: 0,
|
|
|
|
|
|
Version: "7",
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-06-20 17:00:56 +08:00
|
|
|
|
type TomeeHandler struct {
|
2025-07-26 02:14:54 +00:00
|
|
|
|
Callback func(conn *entity.Conn, data TomeeHeader)
|
2025-06-20 17:00:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func NewTomeeHandler() *TomeeHandler {
|
2025-06-23 10:15:22 +08:00
|
|
|
|
return &TomeeHandler{}
|
2025-06-20 17:00:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Handle entry receiver
|
2025-06-24 22:09:05 +08:00
|
|
|
|
func (h *TomeeHandler) Handle(c gnet.Conn, data []byte) { //处理接收到的数据 ,
|
2025-06-23 10:15:22 +08:00
|
|
|
|
//fmt.Println("接收数据", data)
|
|
|
|
|
|
|
|
|
|
|
|
header := TomeeHeader{}
|
2025-06-20 17:00:56 +08:00
|
|
|
|
|
2025-06-23 10:15:22 +08:00
|
|
|
|
tempdata := bytearray.CreateByteArray(data)
|
|
|
|
|
|
header.Len, _ = tempdata.ReadUInt32()
|
|
|
|
|
|
header.Version, _ = tempdata.ReadString(1)
|
2025-07-15 11:24:49 +08:00
|
|
|
|
header.CMD, _ = tempdata.ReadUInt32()
|
|
|
|
|
|
//header.CMD = cmd.EnumCommandID(_CMD)
|
2025-06-23 10:15:22 +08:00
|
|
|
|
header.UserID, _ = tempdata.ReadUInt32()
|
|
|
|
|
|
|
|
|
|
|
|
header.Result, _ = tempdata.ReadUInt32()
|
|
|
|
|
|
header.Data = tempdata.BytesAvailable()
|
|
|
|
|
|
//fmt.Println("接收封包", header)
|
2025-08-17 21:55:15 +08:00
|
|
|
|
h.Callback(entity.NewConn(c), header)
|
2025-06-23 10:15:22 +08:00
|
|
|
|
//return header
|
|
|
|
|
|
}
|
2025-07-14 11:08:30 +08:00
|
|
|
|
|
|
|
|
|
|
// Pack 将给定的数据打包成一个字节切片。
|
|
|
|
|
|
// 该方法处理的数据类型包括指针、切片和结构体。
|
|
|
|
|
|
// 对于指针类型,会解引用以获取实际值。
|
|
|
|
|
|
// 切片类型直接转换为字节切片。
|
|
|
|
|
|
// 结构体类型使用struc库进行序列化。
|
|
|
|
|
|
// 最后,将数据长度、版本号、命令码、用户ID和结果代码一并打包进返回的字节切片中。
|
2025-07-14 11:07:13 +08:00
|
|
|
|
func (h *TomeeHeader) Pack(data any) []byte { //组包
|
2025-08-17 21:55:15 +08:00
|
|
|
|
//h.Result = 0//默认置0
|
2025-07-14 11:07:13 +08:00
|
|
|
|
|
|
|
|
|
|
//t := reflect.TypeOf(data)
|
|
|
|
|
|
tv := reflect.ValueOf(data)
|
|
|
|
|
|
var datar []byte
|
|
|
|
|
|
|
|
|
|
|
|
// 处理指针类型
|
|
|
|
|
|
if tv.Kind() == reflect.Ptr {
|
|
|
|
|
|
//tv = t.Elem() // 获取指针指向的类型
|
|
|
|
|
|
tv = tv.Elem() // 获取指针指向的值
|
|
|
|
|
|
}
|
|
|
|
|
|
//.Println(t.Kind())
|
|
|
|
|
|
//t1 := tv.Interface()
|
|
|
|
|
|
//fmt.Println(t1)
|
|
|
|
|
|
switch tv.Kind() {
|
|
|
|
|
|
|
|
|
|
|
|
case reflect.Slice:
|
|
|
|
|
|
datar = data.([]byte)
|
|
|
|
|
|
//p.Conn.Write(p.pack(cmd, data.([]byte))) //写入数据
|
|
|
|
|
|
|
|
|
|
|
|
case reflect.Struct:
|
|
|
|
|
|
var data1 bytes.Buffer
|
|
|
|
|
|
err := struc.Pack(&data1, data)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
fmt.Println(err)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
datar = data1.Bytes()
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
datar = []byte{}
|
|
|
|
|
|
// fmt.Println(err, datar)
|
|
|
|
|
|
// p.Conn.Write(p.pack(cmd, data))
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
h.Len = uint32(len(datar) + 17)
|
|
|
|
|
|
|
|
|
|
|
|
by := bytearray.CreateByteArray()
|
|
|
|
|
|
by.WriteUInt32(h.Len)
|
|
|
|
|
|
by.WriteString(h.Version)
|
|
|
|
|
|
by.WriteUInt32(uint32(h.CMD))
|
|
|
|
|
|
by.WriteUInt32(h.UserID)
|
|
|
|
|
|
by.WriteUInt32(h.Result)
|
|
|
|
|
|
by.Write(datar)
|
|
|
|
|
|
|
|
|
|
|
|
return by.Bytes()
|
|
|
|
|
|
|
2025-07-15 21:11:56 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-07-16 11:30:37 +08:00
|
|
|
|
// var _ Blazingservice = (*TomeeHeader)(nil)
|
|
|
|
|
|
|
|
|
|
|
|
// type Blazingservice interface {
|
|
|
|
|
|
// Ret() []byte
|
|
|
|
|
|
// }
|
2025-07-15 11:24:49 +08:00
|
|
|
|
|
|
|
|
|
|
// MergeBytes 将多个字节数组合并为一个
|
|
|
|
|
|
func MergeBytes(arrays ...[]byte) []byte {
|
|
|
|
|
|
// 计算所有数组的总长度
|
|
|
|
|
|
totalLen := 0
|
|
|
|
|
|
for _, arr := range arrays {
|
|
|
|
|
|
totalLen += len(arr)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 创建结果切片
|
|
|
|
|
|
result := make([]byte, totalLen)
|
|
|
|
|
|
|
|
|
|
|
|
// 逐个复制数组内容
|
|
|
|
|
|
currentIndex := 0
|
|
|
|
|
|
for _, arr := range arrays {
|
|
|
|
|
|
copy(result[currentIndex:], arr)
|
|
|
|
|
|
currentIndex += len(arr)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return result
|
|
|
|
|
|
}
|