Não pode escolher mais do que 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.
 
 

85 linhas
3.4 KiB

  1. using DotNetty.Buffers;
  2. using DotNetty.Transport.Channels;
  3. using JT809.Protocol;
  4. using System;
  5. using Microsoft.Extensions.Logging;
  6. using JT809.Protocol.Exceptions;
  7. using JT809.DotNetty.Core.Services;
  8. using JT809.DotNetty.Core;
  9. using JT809.DotNetty.Core.Handlers;
  10. using JT809.DotNetty.Core.Metadata;
  11. using JT809.DotNetty.Core.Enums;
  12. namespace JT809.DotNetty.Tcp.Handlers
  13. {
  14. /// <summary>
  15. /// JT809服务端处理程序
  16. /// </summary>
  17. internal class JT809TcpServerHandler : SimpleChannelInboundHandler<byte[]>
  18. {
  19. private readonly JT809MainMsgIdHandlerBase handler;
  20. private readonly JT809SessionManager jT809SessionManager;
  21. private readonly JT809AtomicCounterService jT809AtomicCounterService;
  22. private readonly ILogger<JT809TcpServerHandler> logger;
  23. public JT809TcpServerHandler(
  24. ILoggerFactory loggerFactory,
  25. JT809MainMsgIdHandlerBase handler,
  26. JT809AtomicCounterServiceFactory jT809AtomicCounterServiceFactorty,
  27. JT809SessionManager jT809SessionManager
  28. )
  29. {
  30. this.handler = handler;
  31. this.jT809SessionManager = jT809SessionManager;
  32. this.jT809AtomicCounterService = jT809AtomicCounterServiceFactorty.Create(JT809AtomicCounterType.ServerMain.ToString()); ;
  33. logger = loggerFactory.CreateLogger<JT809TcpServerHandler>();
  34. }
  35. protected override void ChannelRead0(IChannelHandlerContext ctx, byte[] msg)
  36. {
  37. try
  38. {
  39. JT809Package jT809Package = JT809Serializer.Deserialize(msg);
  40. jT809AtomicCounterService.MsgSuccessIncrement();
  41. if (logger.IsEnabled(LogLevel.Debug))
  42. {
  43. logger.LogDebug("accept package success count<<<" + jT809AtomicCounterService.MsgSuccessCount.ToString());
  44. }
  45. jT809SessionManager.TryAdd(ctx.Channel, jT809Package.Header.MsgGNSSCENTERID);
  46. Func<JT809Request, JT809Response> handlerFunc;
  47. if (handler.HandlerDict.TryGetValue(jT809Package.Header.BusinessType, out handlerFunc))
  48. {
  49. JT809Response jT808Response = handlerFunc(new JT809Request(jT809Package, msg));
  50. if (jT808Response != null)
  51. {
  52. var sendData = JT809Serializer.Serialize(jT808Response.Package, jT808Response.MinBufferSize);
  53. ctx.WriteAndFlushAsync(Unpooled.WrappedBuffer(sendData));
  54. }
  55. }
  56. }
  57. catch (JT809Exception ex)
  58. {
  59. jT809AtomicCounterService.MsgFailIncrement();
  60. if (logger.IsEnabled(LogLevel.Error))
  61. {
  62. logger.LogError("accept package fail count<<<" + jT809AtomicCounterService.MsgFailCount.ToString());
  63. logger.LogError(ex, "accept msg<<<" + ByteBufferUtil.HexDump(msg));
  64. }
  65. }
  66. catch (Exception ex)
  67. {
  68. jT809AtomicCounterService.MsgFailIncrement();
  69. if (logger.IsEnabled(LogLevel.Error))
  70. {
  71. logger.LogError("accept package fail count<<<" + jT809AtomicCounterService.MsgFailCount.ToString());
  72. logger.LogError(ex, "accept msg<<<" + ByteBufferUtil.HexDump(msg));
  73. }
  74. }
  75. }
  76. }
  77. }