97 lines
4.2 KiB
C#
Raw Normal View History

2025-10-27 17:31:37 +08:00
using JiShe.ServicePro.Core;
using JiShe.ServicePro.Encrypt;
2025-10-27 17:31:37 +08:00
2025-05-27 14:27:50 +08:00
namespace JiShe.IoT;
2025-05-27 14:02:24 +08:00
public class Program
{
public static async Task<int> Main(string[] args)
{
try
2025-09-09 23:41:46 +08:00
{
//var options = new Yitter.IdGenerator.IdGeneratorOptions(2);
//Yitter.IdGenerator.YitIdHelper.SetIdGenerator(options);
//long nanosecondsFromSnowflakeId = ServicePro.Core.TimestampHelper.NextUnixNanosecondsFromSnowflakeId();
//long nanosecondsDateOffset = ServicePro.Core.TimestampHelper.ToUnixTimeNanoseconds(DateTimeOffset.UtcNow);
BusinessSystemAggregation.Dto.BatchQueryDeviceDataInfoInput batchQueryDeviceDataInfoInput = new BusinessSystemAggregation.Dto.BatchQueryDeviceDataInfoInput()
{
DeviceType = ServicePro.Enums.DeviceTypeEnum.SUB_DEVICE,
DeviceAddresses = new List<string>()
{
"000000000001"
},
BeginTime = new DateTime(2025,10,29),
EndTime = new DateTime(2025, 10, 31),
IoTDataType = "Data",
};
OpenApiRequest openApiRequest = new OpenApiRequest()
{
Message = batchQueryDeviceDataInfoInput.Serialize(),
Signature = "admin:admin123",
Timestamp = 1762185062034,
Nonce = "44110100",
};
var signature = EncryptUtil.OpenApiSignature(openApiRequest.Message, openApiRequest.Timestamp, "SIcPQnpMgaFDmNlIjNmzq5smshz7cKrh", openApiRequest.Nonce);
openApiRequest.Signature = signature.Item2;
2025-10-27 17:31:37 +08:00
string signatureSTR = openApiRequest.Serialize();
2025-10-27 17:31:37 +08:00
2025-08-20 11:26:00 +08:00
//string text = Convert.ToBase64String(Encoding.UTF8.GetBytes("admin:admin123"));
2025-08-19 14:27:24 +08:00
Log.Information("JiShe.IoT.HttpApi.Host.");
2025-05-27 14:02:24 +08:00
var builder = WebApplication.CreateBuilder(args);
builder.Host
.AddAppSettingsSecretsJson()
.UseAutofac()
.UseSerilog((context, loggerConfiguration) =>
{
SerilogToEsExtensions.SetSerilogConfiguration(
loggerConfiguration,
context.Configuration);
2025-08-19 16:44:04 +08:00
})
.ConfigureAppConfiguration((context, builder) =>
{
var env = context.HostingEnvironment.EnvironmentName;
Log.Information("当前环境 " + env);
2025-08-19 16:44:04 +08:00
string[] filePathArray = new string[] { Environment.CurrentDirectory, "configs" };
string jsonPath = Path.Combine(filePathArray);
builder.AddJsonFile(Path.Combine(jsonPath, "appsettings.json"), false, true);
builder.AddJsonFile(Path.Combine(jsonPath, $"appsettings.{env}.json"), false, true);
2025-05-27 14:02:24 +08:00
});
2025-08-19 16:44:04 +08:00
2025-05-27 14:27:50 +08:00
await builder.AddApplicationAsync<JiShe.IoT.IoTHttpApiHostModule>();
2025-09-09 23:41:46 +08:00
builder.WebHost.ConfigureKestrel((context, options) =>
{
options.Limits.MaxRequestBodySize = 100 * 1024 * 1024; // 100MB null不受限制
2025-09-09 23:41:46 +08:00
options.Limits.KeepAliveTimeout = TimeSpan.FromMinutes(2);
options.Limits.RequestHeadersTimeout = TimeSpan.FromMinutes(1);
2025-09-10 09:05:05 +08:00
//获取或设置请求正文的最小数据速率(字节/秒。将此属性设置为NULL表示不应强制执行最小数据速率。////获取或设置请求正文的最小数据速率(字节/秒。将此属性设置为NULL表示不应强制执行最小数据速率。
2025-09-10 09:05:05 +08:00
options.Limits.MinRequestBodyDataRate = null;//new MinDataRate(bytesPerSecond: 2048, gracePeriod: TimeSpan.FromSeconds(10));
2025-09-09 23:41:46 +08:00
});
2025-07-08 22:24:26 +08:00
builder.WebHost.UseUrls($"http://+:10500");
2025-05-27 14:02:24 +08:00
var app = builder.Build();
await app.InitializeApplicationAsync();
await app.RunAsync();
return 0;
}
catch (Exception ex)
{
if (ex is HostAbortedException)
{
throw;
}
Log.Fatal(ex, "Host terminated unexpectedly!");
return 1;
}
finally
{
await Log.CloseAndFlushAsync();
}
}
}