148 lines
5.2 KiB
C#
148 lines
5.2 KiB
C#
using Hei.Captcha;
|
||
using Infrastructure;
|
||
using Infrastructure.Extensions;
|
||
using Microsoft.AspNetCore.Authentication.JwtBearer;
|
||
using Microsoft.AspNetCore.Builder;
|
||
using Microsoft.AspNetCore.DataProtection;
|
||
using Microsoft.AspNetCore.Hosting;
|
||
using Microsoft.AspNetCore.Http;
|
||
using Microsoft.Extensions.Configuration;
|
||
using Microsoft.Extensions.DependencyInjection;
|
||
using Microsoft.Extensions.Hosting;
|
||
using System;
|
||
using System.IO;
|
||
using System.Threading.Tasks;
|
||
using ZR.Admin.WebApi.Extensions;
|
||
using ZR.Admin.WebApi.Filters;
|
||
using ZR.Admin.WebApi.Framework;
|
||
using ZR.Admin.WebApi.Middleware;
|
||
using ZR.Common.Cache;
|
||
|
||
namespace ZR.Admin.WebApi
|
||
{
|
||
public class Startup
|
||
{
|
||
public Startup(IConfiguration configuration)
|
||
{
|
||
Configuration = configuration;
|
||
}
|
||
private NLog.Logger logger = NLog.LogManager.GetCurrentClassLogger();
|
||
public IConfiguration Configuration { get; }
|
||
public void ConfigureServices(IServiceCollection services)
|
||
{
|
||
string corsUrls = Configuration["sysConfig:cors"];
|
||
|
||
//配置跨域
|
||
services.AddCors(c =>
|
||
{
|
||
c.AddPolicy("Policy", policy =>
|
||
{
|
||
policy.WithOrigins(corsUrls.Split(',', StringSplitOptions.RemoveEmptyEntries))
|
||
.AllowAnyHeader()//允许任意头
|
||
.AllowCredentials()//允许cookie
|
||
.AllowAnyMethod();//允许任意方法
|
||
});
|
||
});
|
||
//消除Error unprotecting the session cookie警告
|
||
services.AddDataProtection()
|
||
.PersistKeysToFileSystem(new DirectoryInfo(Directory.GetCurrentDirectory() + Path.DirectorySeparatorChar + "DataProtection"));
|
||
//普通验证码
|
||
services.AddHeiCaptcha();
|
||
services.AddSession();
|
||
services.AddHttpContextAccessor();
|
||
|
||
//绑定整个对象到Model上
|
||
services.Configure<OptionsSetting>(Configuration);
|
||
|
||
//Cookie 认证
|
||
services.AddAuthentication(options =>
|
||
{
|
||
options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
|
||
options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
|
||
}).AddCookie()
|
||
.AddJwtBearer(o =>
|
||
{
|
||
o.TokenValidationParameters = JwtUtil.ValidParameters();
|
||
});
|
||
|
||
InjectServices(services, Configuration);
|
||
|
||
services.AddMvc(options =>
|
||
{
|
||
options.Filters.Add(typeof(GlobalActionMonitor));//全局注册异常
|
||
})
|
||
.AddJsonOptions(options =>
|
||
{
|
||
options.JsonSerializerOptions.Converters.Add(new JsonConverterUtil.DateTimeConverter());
|
||
options.JsonSerializerOptions.Converters.Add(new JsonConverterUtil.DateTimeNullConverter());
|
||
});
|
||
|
||
services.AddSwaggerConfig();
|
||
}
|
||
|
||
// 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.UseSwagger();
|
||
//使可以多次多去body内容
|
||
app.Use((context, next) =>
|
||
{
|
||
context.Request.EnableBuffering();
|
||
return next();
|
||
});
|
||
//开启访问静态文件/wwwroot目录文件,要放在UseRouting前面
|
||
app.UseStaticFiles();
|
||
|
||
app.UseRouting();
|
||
app.UseCors("Policy");//要放在app.UseEndpoints前。
|
||
|
||
//app.UseAuthentication会启用Authentication中间件,该中间件会根据当前Http请求中的Cookie信息来设置HttpContext.User属性(后面会用到),
|
||
//所以只有在app.UseAuthentication方法之后注册的中间件才能够从HttpContext.User中读取到值,
|
||
//这也是为什么上面强调app.UseAuthentication方法一定要放在下面的app.UseMvc方法前面,因为只有这样ASP.NET Core的MVC中间件中才能读取到HttpContext.User的值。
|
||
//1.先开启认证
|
||
app.UseAuthentication();
|
||
//2.再开启授权
|
||
app.UseAuthorization();
|
||
app.UseSession();
|
||
app.UseResponseCaching();
|
||
|
||
// 恢复/启动任务
|
||
app.UseAddTaskSchedulers();
|
||
|
||
app.UseMiddleware<GlobalExceptionMiddleware>();
|
||
|
||
app.UseEndpoints(endpoints =>
|
||
{
|
||
endpoints.MapControllerRoute(
|
||
name: "default",
|
||
pattern: "{controller=Home}/{action=Index}/{id?}");
|
||
});
|
||
}
|
||
|
||
/// <summary>
|
||
/// 注册Services服务
|
||
/// </summary>
|
||
/// <param name="services"></param>
|
||
/// <param name="configuration"></param>
|
||
private void InjectServices(IServiceCollection services, IConfiguration configuration)
|
||
{
|
||
services.AddAppService();
|
||
services.AddSingleton(new AppSettings(configuration));
|
||
//开启计划任务
|
||
services.AddTaskSchedulers();
|
||
//初始化db
|
||
DbExtension.AddDb(configuration);
|
||
|
||
//注册REDIS 服务
|
||
Task.Run(() =>
|
||
{
|
||
//RedisServer.Initalize();
|
||
});
|
||
}
|
||
}
|
||
}
|