123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- using Microsoft.AspNetCore.Authentication.JwtBearer;
- using Microsoft.AspNetCore.Builder;
- using Microsoft.AspNetCore.Hosting;
- using Microsoft.EntityFrameworkCore;
- using Microsoft.EntityFrameworkCore.Query;
- using Microsoft.EntityFrameworkCore.SqlServer.Query.Internal;
- using Microsoft.Extensions.Configuration;
- using Microsoft.Extensions.DependencyInjection;
- using Microsoft.Extensions.Hosting;
- using Microsoft.IdentityModel.Tokens;
- using Newtonsoft.Json;
- using Quartz;
- using Quartz.Impl;
- using System;
- using System.Text;
- using System.Text.Json.Serialization;
- using wispro.sp.api.Job;
- using wispro.sp.api.Services;
- namespace wispro.sp.api
- {
- public class Startup
- {
- readonly string MyAllowSpecificOrigins = "_myAllowSpecificOrigins";
- 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.AddCors(options =>
- {
- options.AddPolicy(MyAllowSpecificOrigins,
- builder =>
- {
- builder.AllowAnyOrigin()
- .AllowAnyMethod()
- .AllowAnyHeader();
- });
- });
-
- services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme).AddJwtBearer(option =>
- {
- option.TokenValidationParameters = new TokenValidationParameters
- {
- ValidateIssuer = false,
- ValidateAudience = false,
- ValidateLifetime = true,
- ValidateIssuerSigningKey = true,
- ValidIssuer = Configuration["jwt:Issuer"],
- IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["jwt:Key"])),
- ClockSkew = TimeSpan.Zero
- };
- });
- //services.AddControllers().AddNewtonsoftJson(o =>
- //{
- // o.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore;
- // o.SerializerSettings.DefaultValueHandling = DefaultValueHandling.Ignore;
- // o.SerializerSettings.NullValueHandling = NullValueHandling.Ignore;
- //});
- services.AddControllers()
- .AddJsonOptions(options =>
- {
- //options.JsonSerializerOptions.ReferenceHandler = ReferenceHandler.Preserve;
- //json循环最大深度 如果你所需的资源确实超过了32层,可以加深深度来解决
- options.JsonSerializerOptions.MaxDepth = 64;
- //null值不序列化为json
- options.JsonSerializerOptions.IgnoreNullValues = true;
-
- });
- services.AddDbContext<spDbContext>(optionsAction =>
- optionsAction.UseSqlServer(Configuration.GetConnectionString("DefaultConnect"))
- .ReplaceService<IQueryTranslationPostprocessorFactory, SqlServer2008QueryTranslationPostprocessorFactory>()
- );
- services.AddSingleton<ISchedulerFactory, StdSchedulerFactory>();
- services.AddSingleton<IFileTaskService, FileTaskCacheService>();
- services.AddMemoryCache();
- services.Configure<IISServerOptions>(options => {
- options.MaxRequestBodySize = int.MaxValue;
- });
- }
- // 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.UseRouting();
- app.UseCors(MyAllowSpecificOrigins);
- app.UseAuthentication();
- app.UseAuthorization();
- //app.UseHttpsRedirection();
- app.UseEndpoints(endpoints =>
- {
- endpoints.MapControllers();
- });
-
- }
- }
- }
|