Commit fb1b3752 authored by Him188's avatar Him188

Enhance debugger tools

parent 47e02cd2
...@@ -95,8 +95,9 @@ private fun processFullPacketWithoutLength(packet: ByteReadPacket) { ...@@ -95,8 +95,9 @@ private fun processFullPacketWithoutLength(packet: ByteReadPacket) {
val bytes = it.data.readBytes() val bytes = it.data.readBytes()
if (flag2 == 2 && it.packetFactory != null) { if (flag2 == 2 && it.packetFactory != null) {
PacketLogger.debug("Oicq Reuqest= " + bytes.toUHexString()) PacketLogger.debug("Oicq Reuqest= " + bytes.toUHexString())
try{ try {
bytes.toReadPacket().parseOicqResponse { bytes.toReadPacket().parseOicqResponse {
debugIfFail {
if (it.packetFactory.commandName == "wtlogin.login") { if (it.packetFactory.commandName == "wtlogin.login") {
DebugLogger.info("服务器发来了 wtlogin.login. 正在解析 key") DebugLogger.info("服务器发来了 wtlogin.login. 正在解析 key")
try { try {
...@@ -104,10 +105,14 @@ private fun processFullPacketWithoutLength(packet: ByteReadPacket) { ...@@ -104,10 +105,14 @@ private fun processFullPacketWithoutLength(packet: ByteReadPacket) {
println("subCommand=$subCommand") println("subCommand=$subCommand")
val type = readUByte().toInt() val type = readUByte().toInt()
println("type=$type") println("type=$type")
if (type == 0) {
discardExact(2) discardExact(2)
val tlvMap: Map<Int, ByteArray> = this.readTLVMap() val tlvMap: Map<Int, ByteArray> = this.readTLVMap()
println("tlvMap: ")
tlvMap.forEach {
println(it.key.toShort().toUHexString() + " = " + it.value.toUHexString())
}
tlvMap[0x119]?.let { t119Data -> tlvMap[0x119]?.let { t119Data ->
t119Data.decryptBy(tgtgtKey).toReadPacket().debugPrint("0x119data").apply { t119Data.decryptBy(tgtgtKey).toReadPacket().debugPrint("0x119data").apply {
discardExact(2) // always discarded. 00 1C discardExact(2) // always discarded. 00 1C
...@@ -123,12 +128,12 @@ private fun processFullPacketWithoutLength(packet: ByteReadPacket) { ...@@ -123,12 +128,12 @@ private fun processFullPacketWithoutLength(packet: ByteReadPacket) {
DebugLogger.info("D2Key=${D2Key.toUHexString()}") DebugLogger.info("D2Key=${D2Key.toUHexString()}")
} }
} }
}
} catch (e: Exception) { } catch (e: Exception) {
e.printStackTrace() e.printStackTrace()
} }
} }
} }
}
} catch (e: Exception) { } catch (e: Exception) {
e.printStackTrace() e.printStackTrace()
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment