using System; using System.Collections.Generic; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Http.Features; using Microsoft.AspNetCore.StaticFiles; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Hosting; namespace MySystem { public class Startup { public Startup(IConfiguration configuration) { Configuration = configuration; } public IConfiguration Configuration { get; } // This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddControllersWithViews(); services.AddRouting(options => { options.LowercaseUrls = true; }); services.AddSingleton(); services.AddCors(option => option.AddPolicy("cors", policy => policy.AllowAnyHeader().AllowAnyMethod().AllowCredentials().SetIsOriginAllowed(_ => true))); services.AddMvc(options => { options.EnableEndpointRouting = false; options.Filters.Add(typeof(GlobalExceptions)); }); services.AddSession(options => { // 设置 Session 过期时间 options.IdleTimeout = TimeSpan.FromHours(1); options.Cookie.HttpOnly = true; }); services.Configure(x => { x.MultipartBodyLengthLimit = 50 * 1024 * 1024;//不到300M }); MySystemLib.SystemPublicFuction.appcheck = "success"; string conn = Configuration["Setting:SqlConnStr"]; Dictionary> tables = new Dictionary>(); System.Data.DataTable tablecollection = Library.CustomerSqlConn.dtable("select DISTINCT TABLE_NAME from information_schema.columns where table_schema = 'QrCodePlateMainServer'", conn); foreach (System.Data.DataRow subtable in tablecollection.Rows) { Dictionary Columns = new Dictionary(); System.Data.DataTable columncollection = Library.CustomerSqlConn.dtable("select COLUMN_NAME,DATA_TYPE from information_schema.columns where table_schema = 'QrCodePlateMainServer' and TABLE_NAME='" + subtable["TABLE_NAME"].ToString() + "'", conn); foreach (System.Data.DataRow column in columncollection.Rows) { string datatype = column["DATA_TYPE"].ToString(); if (datatype == "decimal") { datatype = "numeric"; } Columns.Add(column["COLUMN_NAME"].ToString(), datatype); } tables.Add(subtable["TABLE_NAME"].ToString(), Columns); } MySystemLib.SystemPublicFuction.dbtables = tables; RedisDbconn.csredis = new CSRedis.CSRedisClient(Configuration["Setting:RedisConnStr"]); } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); // app.UseExceptionHandler("/Home/Error"); Library.ConfigurationManager.EnvironmentFlag = 1; } else { app.UseExceptionHandler("/Home/Error"); app.UseHsts(); Library.ConfigurationManager.EnvironmentFlag = 2; } Library.function.WritePage("/", "WebRootPath.txt", env.WebRootPath); app.UseStaticFiles(); app.UseStaticFiles(new StaticFileOptions { ContentTypeProvider = new FileExtensionContentTypeProvider(new Dictionary { { ".apk", "application/vnd.android.package-archive" } }) }); app.UseCors("cors"); app.UseAuthentication(); app.UseRouting(); app.UseAuthorization(); app.UseSession(); app.UseEndpoints(endpoints => { endpoints.MapControllerRoute( name: "default", pattern: "{controller=Home}/{action=Index}/{Id?}"); }); #region 必须打开的 //老平台 StatService.Instance.Start(); //实时统计交易额 StatResetService.Instance.StartReset(); //重置交易额 StatService.Instance.StartPosActNum(); //实时统计激活数 StatNewService.Instance.StartMer(); //实时统计商户交易额 StatNewService.Instance.CreateTable(); //生成新的分表 //好哒 StatService2.Instance.Start(); //实时统计交易额 StatResetService2.Instance.StartReset(); //重置交易额 StatService2.Instance.StartPosActNum(); //实时统计激活数 StatNewService2.Instance.StartMer(); //实时统计商户交易额 StatNewService2.Instance.CreateTable(); //生成新的分表 #endregion } } }