using System.Security.Cryptography; using System.Text; using MassTransit; using MassTransit.Mediator; using Microsoft.Extensions.Logging; using NetCoreServer; namespace Server; public class ChannelSession : TcpSession { private readonly IMediator _mediator; private readonly ILogger _logger; private static readonly byte[] Key = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, 7 } .Reverse().ToArray(); private static readonly byte[] IV = new byte[] { 0xfe, 220, 0xba, 0x98, 0x76, 0x54, 50, 0x10, 15, 30, 0x2d, 60, 0x4b, 90, 0x69, 120 }.Reverse().ToArray(); private readonly ICryptoTransform _encryptor; private readonly ICryptoTransform _decryptor; public ChannelSession(TcpServer server, IMediator mediator, ILogger logger) : base(server) { _mediator = mediator; _logger = logger; var aes = Aes.Create(); aes.Key = Key; aes.IV = IV; aes.Padding = PaddingMode.None; aes.Mode = CipherMode.ECB; _decryptor = aes.CreateDecryptor(aes.Key, aes.IV); _encryptor = aes.CreateEncryptor(aes.Key, aes.IV); } protected override void OnReceived(byte[] buffer, long offset, long size) { try { using (var ms = new MemoryStream(Decrypt(buffer))) using (var cs = new CryptoStream(ms, _decryptor, CryptoStreamMode.Read)) { cs.Read(buffer); } base.OnReceived(buffer, offset, size); } catch (CryptographicException ex) { _logger.LogError("An error has occured while decrypting: {ErrorMessage}", ex.Message); _logger.LogError("Default buffer message: {Message}", Encoding.ASCII.GetString(buffer)); } } private byte[] Decrypt(byte[] buffer) { for (int i = 0; i < buffer.Length; ++i) { buffer[i] = (byte)(buffer[i] ^ i ^ (3 * (0xFE - i))); } return buffer; } }