NettyClientHandler.java 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package com.mes.netty;
  2. import com.mes.ui.MesClient;
  3. import com.mes.ui.MesRevice;
  4. import com.mes.util.HttpUtils;
  5. import io.netty.channel.Channel;
  6. import io.netty.channel.ChannelHandlerContext;
  7. import io.netty.channel.ChannelInboundHandlerAdapter;
  8. import org.slf4j.Logger;
  9. import org.slf4j.LoggerFactory;
  10. import java.text.SimpleDateFormat;
  11. import java.util.Date;
  12. public class NettyClientHandler extends ChannelInboundHandlerAdapter {
  13. public static final Logger log = LoggerFactory.getLogger(NettyClientHandler.class);
  14. private final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  15. public static byte[] responseByte;
  16. @Override
  17. public void channelActive(ChannelHandlerContext ctx) throws Exception {
  18. log.info("mes connecting:" + sdf.format(new Date()));
  19. }
  20. @Override
  21. public void handlerRemoved(ChannelHandlerContext ctx) throws Exception {
  22. Channel channel = ctx.channel();
  23. log.error("close tcp, ip:" + channel.remoteAddress());
  24. MesClient.tcp_connect_flag = false;
  25. MesClient.setTcpStatus();
  26. // 关闭通道
  27. channel.close();
  28. }
  29. @Override
  30. public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
  31. log.info("msg:"+msg);
  32. String mes_msg = formatResult(msg.toString());
  33. if(mes_msg == null || mes_msg.isEmpty()){ // error msg
  34. return;
  35. }
  36. String msg_type = ProtocolParam.getMsgType(mes_msg);
  37. log.info("msg_type="+msg_type);
  38. String processMsgRet = MesMsgUtils.processMsg(mes_msg, msg_type);
  39. log.info("processMsgRet="+processMsgRet);
  40. switch(msg_type) {
  41. case "AQDW": // 查询质量
  42. MesRevice.checkQualityRevice(processMsgRet,mes_msg);
  43. break;
  44. case "MKSW":
  45. MesRevice.startRevice(processMsgRet,mes_msg);
  46. break;
  47. case "MBDW":
  48. MesRevice.bindRevice(processMsgRet,mes_msg);
  49. break;
  50. case "MJBW":
  51. MesRevice.unbindRevice(processMsgRet,mes_msg);
  52. break;
  53. case "MQDW":
  54. MesRevice.updateResultRevice(processMsgRet,mes_msg);
  55. break;
  56. }
  57. }
  58. @Override
  59. public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
  60. ctx.close();
  61. }
  62. private String formatResult(String msg){
  63. log.error("length:" + msg.length() + " content:" + msg);
  64. String msgType = msg.substring(0,2).trim();
  65. if(msgType.equals("OK")){
  66. return msg.substring(3,msg.length());
  67. }else{
  68. return "";
  69. }
  70. }
  71. }