Files
Yi.Framework/Yi.Framework.Net6/Yi.Framework.SMSProcessor/SendWorker.cs
2021-12-25 14:50:54 +08:00

69 lines
2.4 KiB
C#
Raw Blame History

using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Yi.Framework.Common.Const;
using Yi.Framework.Common.IOCOptions;
using Yi.Framework.Common.Models;
using Yi.Framework.Common.QueueModel;
using Yi.Framework.Core;
using Yi.Framework.Core.ConsulExtend;
using Yi.Framework.Core.SMS;
namespace Yi.Framework.SMSProcessor
{
public class SendWorker : BackgroundService
{
private readonly ILogger<SendWorker> _logger;
private readonly RabbitMQInvoker _RabbitMQInvoker;
private readonly AliyunSMSInvoker _aliyunSMSInvoker;
public SendWorker(ILogger<SendWorker> logger, RabbitMQInvoker rabbitMQInvoker,AliyunSMSInvoker aliyunSMSInvoker)
{
this._logger = logger;
this._RabbitMQInvoker = rabbitMQInvoker;
_aliyunSMSInvoker = aliyunSMSInvoker;
}
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
RabbitMQConsumerModel rabbitMQConsumerModel = new RabbitMQConsumerModel()
{
ExchangeName = RabbitConst.SMS_Exchange,
QueueName = RabbitConst.SMS_Queue_Send
};
HttpClient _HttpClient = new HttpClient();
this._RabbitMQInvoker.RegistReciveAction(rabbitMQConsumerModel, message =>
{
var data= Common.Helper.JsonHelper.StrToObj<SMSQueueModel>(message);
try
{
_aliyunSMSInvoker.SendCode(data.code, data.phone);
return true;
}
catch (Exception ex)
{
var logModel = new LogModel()
{
OriginalClassName = this.GetType().FullName,
OriginalMethodName = nameof(ExecuteAsync),
Remark = "<22><>Ϣ<EFBFBD><CFA2><EFBFBD>д<EFBFBD><D0B4><EFBFBD><EFBFBD><EFBFBD>־"
};
this._logger.LogError(ex, $"{nameof(SendWorker)}, Exception:{ex.Message}", JsonConvert.SerializeObject(logModel));
return false;
}
});
await Task.CompletedTask;
}
}
}