You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

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