From 5e232be34f141a946b0bc00ea10bc4ecb31d4a2c Mon Sep 17 00:00:00 2001 From: riku <risaku@163.com> Date: 星期一, 23 九月 2019 12:58:47 +0800 Subject: [PATCH] 修改数据连接 --- src/main/kotlin/com/flightfeather/obd/socket/ServerHandler.kt | 40 +++++++++++++++++++++++++++++----------- 1 files changed, 29 insertions(+), 11 deletions(-) diff --git a/src/main/kotlin/com/flightfeather/obd/socket/ServerHandler.kt b/src/main/kotlin/com/flightfeather/obd/socket/ServerHandler.kt index 42a6c2a..018a932 100644 --- a/src/main/kotlin/com/flightfeather/obd/socket/ServerHandler.kt +++ b/src/main/kotlin/com/flightfeather/obd/socket/ServerHandler.kt @@ -1,11 +1,11 @@ package com.flightfeather.obd.socket -import com.flightfeather.obd.domain.entity.ObdData -import com.google.gson.Gson -import io.netty.channel.ChannelHandler import io.netty.channel.ChannelHandlerContext import io.netty.channel.ChannelInboundHandlerAdapter import io.netty.util.AttributeKey +import java.lang.StringBuilder +import java.text.SimpleDateFormat +import java.util.* class ServerHandler : ChannelInboundHandlerAdapter() { @@ -14,6 +14,7 @@ override fun channelRegistered(ctx: ChannelHandlerContext?) { super.channelRegistered(ctx) +// ctx?.fireChannelActive() } override fun channelActive(ctx: ChannelHandlerContext?) { @@ -22,15 +23,32 @@ override fun channelRead(ctx: ChannelHandlerContext?, msg: Any?) { super.channelRead(ctx, msg) - if (msg is String) { - MessageManager().dealMsg(msg, ctx) - } -// val attribute = ctx?.channel()?.attr(attributeKey)?.apply { -// if (get() == null) { -// set(data.obdVin) -// } -// } + val sb = StringBuilder() + + if (msg is ByteArray) { + println("------鏀跺埌鐨勫師濮嬫暟鎹細[ip:${ctx?.channel()?.remoteAddress()}] ${SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(Date())}") + msg.forEach { + var a = 0 + a = if (it < 0) { + it + 256 + } else { + it.toInt() + } + val s = if (a < 16) { + "0${a.toString(16)}" + } else { + a.toString(16) + } + print("$s ") + sb.append(s).append(" ") + } + sb.deleteCharAt(sb.length - 1) + } + val str = sb.toString() + if (str.isNotEmpty()) { + MessageManager().dealStringMsg(str, ctx) + } } -- Gitblit v1.9.3