您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 

80 行
3.1 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.Internal;
  12. using JT809.DotNetty.Core.Enums;
  13. namespace JT809.DotNetty.Core.Handlers
  14. {
  15. /// <summary>
  16. /// JT809从链路业务处理程序
  17. /// </summary>
  18. internal class JT809SubordinateServerHandler : SimpleChannelInboundHandler<byte[]>
  19. {
  20. private readonly JT809SubordinateMsgIdHandlerBase handler;
  21. private readonly JT809AtomicCounterService jT809AtomicCounterService;
  22. private readonly ILogger<JT809SubordinateServerHandler> logger;
  23. public JT809SubordinateServerHandler(
  24. ILoggerFactory loggerFactory,
  25. JT809SubordinateMsgIdHandlerBase handler,
  26. JT809AtomicCounterServiceFactory jT809AtomicCounterServiceFactorty
  27. )
  28. {
  29. this.handler = handler;
  30. this.jT809AtomicCounterService = jT809AtomicCounterServiceFactorty.Create(JT809AtomicCounterType.ClientSubordinate.ToString());
  31. logger = loggerFactory.CreateLogger<JT809SubordinateServerHandler>();
  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. Func<JT809Request, JT809Response> handlerFunc;
  44. if (handler.HandlerDict.TryGetValue(jT809Package.Header.BusinessType, out handlerFunc))
  45. {
  46. JT809Response jT808Response = handlerFunc(new JT809Request(jT809Package, msg));
  47. if (jT808Response != null)
  48. {
  49. ctx.WriteAndFlushAsync(jT808Response);
  50. }
  51. }
  52. }
  53. catch (JT809Exception ex)
  54. {
  55. jT809AtomicCounterService.MsgFailIncrement();
  56. if (logger.IsEnabled(LogLevel.Error))
  57. {
  58. logger.LogError("accept package fail count<<<" + jT809AtomicCounterService.MsgFailCount.ToString());
  59. logger.LogError(ex, "accept msg<<<" + ByteBufferUtil.HexDump(msg));
  60. }
  61. }
  62. catch (Exception ex)
  63. {
  64. jT809AtomicCounterService.MsgFailIncrement();
  65. if (logger.IsEnabled(LogLevel.Error))
  66. {
  67. logger.LogError("accept package fail count<<<" + jT809AtomicCounterService.MsgFailCount.ToString());
  68. logger.LogError(ex, "accept msg<<<" + ByteBufferUtil.HexDump(msg));
  69. }
  70. }
  71. }
  72. }
  73. }