From c020f31a67fc5aa5644511bddff075f7ecc85234 Mon Sep 17 00:00:00 2001
From: qinchulong <qinchulong@hnkhzn.com>
Date: 星期二, 27 五月 2025 15:35:27 +0800
Subject: [PATCH] Merge branch 'master' of http://115.159.85.185:8098/r/HuaYiZhongHeng/ZhongHeLiTiKu

---
 代码管理/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Program.cs |  140 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 140 insertions(+), 0 deletions(-)

diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Program.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Program.cs"
new file mode 100644
index 0000000..b48b4d0
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Program.cs"
@@ -0,0 +1,140 @@
+using WIDESEAWCS_Core.Helper;
+using WIDESEAWCS_Core.Extensions;
+using WIDESEAWCS_Core.Middlewares;
+using System.Reflection;
+using WIDESEAWCS_Core.Filter;
+using Newtonsoft.Json.Converters;
+using Newtonsoft.Json.Serialization;
+using Newtonsoft.Json;
+using System.Text;
+using Microsoft.AspNetCore.Mvc.Controllers;
+using Microsoft.Extensions.DependencyInjection.Extensions;
+using Microsoft.AspNetCore.Mvc.ModelBinding.Validation;
+using WIDESEAWCS_Core;
+using WIDESEAWCS_Core.BaseServices;
+using Autofac.Extensions.DependencyInjection;
+using Autofac;
+using WIDESEAWCS_WCSServer.Filter;
+using WIDESEAWCS_Core.Authorization;
+using WIDESEAWCS_Core.Core;
+using WIDESEAWCS_QuartzJob.Seed;
+using Autofac.Core;
+using WIDESEAWCS_QuartzJob.QuartzExtensions;
+using Microsoft.AspNetCore.Builder;
+
+var builder = WebApplication.CreateBuilder(args);
+
+builder.Host.UseServiceProviderFactory(new AutofacServiceProviderFactory()).ConfigureContainer<ContainerBuilder>(builder =>
+{
+    builder.RegisterModule(new AutofacModuleRegister());//带有接口层的服务注入
+    builder.RegisterModule(new QuartzJobAutofacModuleRegister());
+    builder.RegisterModule<AutofacPropertityModuleReg>();//
+}).ConfigureAppConfiguration((hostingContext, config) =>
+{
+    hostingContext.Configuration.ConfigureApplication();
+    config.Sources.Clear();
+    config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: false);
+}); ;
+builder.ConfigureApplication();
+
+
+// 2、配置服务
+builder.Services.AddSingleton(new AppSettings(builder.Configuration));//注册
+builder.Services.AddAllOptionRegister();//读取配置文件
+builder.Services.AddMemoryCacheSetup();//缓存
+builder.Services.AddSqlsugarSetup();//SqlSugar 启动服务
+//builder.Services.AddInitializationHostServiceSetup();//应用初始化服务注入
+builder.Services.AddDbSetup();//Db 启动服务
+
+//builder.Services.AddScoped<QuartzJobCreateDataTabel>();
+//builder.Services.AddHostedService<QuartzJobDataTableHostedService>();
+
+builder.Services.AddAutoMapperSetup();
+
+builder.Services.AddCorsSetup();
+
+builder.Services.AddMiniProfilerSetup();
+
+builder.Services.AddSwaggerSetup();
+
+builder.Services.AddJobSetup();//任务调度 启动服务
+
+builder.Services.AddHttpContextSetup();
+
+builder.Services.AddHostedService<QuartzJobHostedService>();
+
+builder.Services.AddMvc(options =>
+{
+    options.Filters.Add(typeof(ApiAuthorizeFilter));
+    options.Filters.Add(typeof(ActionExecuteFilter));
+});
+
+builder.Services.AddAuthorizationSetup();
+
+builder.Services.AddIpPolicyRateLimitSetup(builder.Configuration);//IPLimit限流 启动服务
+
+builder.Services.AddScoped<UseServiceDIAttribute>();
+
+builder.Services.AddSession();
+
+builder.Services.AddHttpClient();
+
+builder.Services.AddControllers(o =>
+{
+    o.Filters.Add(typeof(GlobalExceptionsFilter));//全局异常
+})
+.AddNewtonsoftJson(options =>
+{
+    options.SerializerSettings.ReferenceLoopHandling = ReferenceLoopHandling.Serialize;
+    //options.SerializerSettings.ContractResolver = new DefaultContractResolver();
+    options.SerializerSettings.ContractResolver = new Newtonsoft.Json.Serialization.CamelCasePropertyNamesContractResolver();
+    options.SerializerSettings.DateFormatString = "yyyy-MM-dd HH:mm:ss";
+    options.SerializerSettings.NullValueHandling = NullValueHandling.Include;
+    options.SerializerSettings.DateTimeZoneHandling = DateTimeZoneHandling.Local;
+    options.SerializerSettings.Converters.Add(new StringEnumConverter());
+});
+// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
+builder.Services.AddEndpointsApiExplorer();
+
+builder.Services.Replace(ServiceDescriptor.Transient<IControllerActivator, ServiceBasedControllerActivator>());
+Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);
+
+
+var app = builder.Build();
+
+// 3、配置中间件
+app.UseMiniProfiler();//性能分析器
+app.ConfigureApplication();//配置文件
+app.UseApplicationSetup();//启动配置
+app.UseSession();
+//if (app.Environment.IsDevelopment())
+{
+    //todo
+    //app.UseSwaggerAuthorized();
+    app.UseSwaggerMiddle(() => Assembly.GetExecutingAssembly().GetManifestResourceStream("WIDESEAWCS_Server.index.html"));
+}//判断是否需要打开swagger
+
+app.UseIpLimitMiddle();
+app.UseApiLogMiddleware();
+//todo
+//app.UseRecordAccessLogsMiddle();
+
+app.UseCors(AppSettings.Get(new string[] { "Cors", "PolicyName" }));
+
+DefaultFilesOptions defaultFilesOptions = new DefaultFilesOptions();
+defaultFilesOptions.DefaultFileNames.Clear();
+defaultFilesOptions.DefaultFileNames.Add("index.html");
+app.UseDefaultFiles(defaultFilesOptions);
+app.UseMiddleware<HttpRequestMiddleware>();
+app.UseStaticFiles();
+app.UseCookiePolicy();
+app.UseStatusCodePages();
+
+app.UseRouting();
+
+app.UseAuthentication();
+app.UseAuthorization();
+
+app.MapControllers();
+
+app.Run();

--
Gitblit v1.9.3