2021-11-04 15:15:00 +08:00
|
|
|
|
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 =>
|
|
|
|
|
|
{
|
2021-11-04 15:38:38 +08:00
|
|
|
|
var data= Common.Helper.JsonHelper.StrToObj<SMSQueueModel>(message);
|
2021-11-04 15:15:00 +08:00
|
|
|
|
try
|
|
|
|
|
|
{
|
2021-11-04 15:38:38 +08:00
|
|
|
|
_aliyunSMSInvoker.SendCode(data.code, data.phone);
|
2021-11-04 15:15:00 +08:00
|
|
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|