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