2020-10-22 14:59:36 +08:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using Autofac;
|
|
|
|
|
using IdentityServer4.AccessTokenValidation;
|
2021-01-04 22:17:49 +08:00
|
|
|
|
using Infrastructure;
|
2020-10-22 14:59:36 +08:00
|
|
|
|
using Infrastructure.Extensions.AutofacManager;
|
|
|
|
|
using Microsoft.AspNetCore.Builder;
|
|
|
|
|
using Microsoft.AspNetCore.DataProtection;
|
2020-12-27 00:00:28 +08:00
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
2020-10-22 14:59:36 +08:00
|
|
|
|
using Microsoft.Extensions.Configuration;
|
|
|
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
|
|
|
using Microsoft.Extensions.FileProviders;
|
|
|
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
using Microsoft.OpenApi.Models;
|
|
|
|
|
using Newtonsoft.Json;
|
|
|
|
|
using OpenAuth.App;
|
|
|
|
|
using OpenAuth.App.HostedService;
|
|
|
|
|
using OpenAuth.Repository;
|
|
|
|
|
using OpenAuth.WebApi.Model;
|
|
|
|
|
using Swashbuckle.AspNetCore.SwaggerUI;
|
|
|
|
|
|
|
|
|
|
namespace OpenAuth.WebApi
|
|
|
|
|
{
|
|
|
|
|
public class Startup
|
|
|
|
|
{
|
|
|
|
|
public IHostEnvironment Environment { get; }
|
|
|
|
|
public IConfiguration Configuration { get; }
|
|
|
|
|
|
|
|
|
|
public Startup(IConfiguration configuration, IHostEnvironment environment)
|
|
|
|
|
{
|
|
|
|
|
Configuration = configuration;
|
|
|
|
|
Environment = environment;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// This method gets called by the runtime. Use this method to add services to the container.
|
|
|
|
|
public void ConfigureServices(IServiceCollection services)
|
|
|
|
|
{
|
2020-12-27 00:00:28 +08:00
|
|
|
|
services.Configure<ApiBehaviorOptions>(options =>
|
|
|
|
|
{
|
|
|
|
|
options.SuppressModelStateInvalidFilter = true;
|
|
|
|
|
});
|
|
|
|
|
|
2020-10-22 14:59:36 +08:00
|
|
|
|
services.AddSingleton(provider =>
|
|
|
|
|
{
|
|
|
|
|
var service = provider.GetRequiredService<ILogger<StartupLogger>>();
|
|
|
|
|
return new StartupLogger(service);
|
|
|
|
|
});
|
|
|
|
|
var logger = services.BuildServiceProvider().GetRequiredService<StartupLogger>();
|
|
|
|
|
|
|
|
|
|
var identityServer = ((ConfigurationSection)Configuration.GetSection("AppSetting:IdentityServerUrl")).Value;
|
|
|
|
|
if (!string.IsNullOrEmpty(identityServer))
|
|
|
|
|
{
|
|
|
|
|
services.AddAuthorization();
|
|
|
|
|
|
|
|
|
|
services.AddAuthentication(IdentityServerAuthenticationDefaults.AuthenticationScheme)
|
|
|
|
|
.AddJwtBearer(options =>
|
|
|
|
|
{
|
|
|
|
|
options.Authority = identityServer;
|
|
|
|
|
options.RequireHttpsMetadata = false; // 指定是否为HTTPS
|
|
|
|
|
options.Audience = "openauthapi";
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
services.AddSwaggerGen(option =>
|
|
|
|
|
{
|
|
|
|
|
option.SwaggerDoc("v1", new OpenApiInfo
|
|
|
|
|
{
|
|
|
|
|
Version = "v1",
|
|
|
|
|
Title = " OpenAuth.WebApi",
|
|
|
|
|
Description = "by yubaolee"
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
logger.LogInformation($"api doc basepath:{AppContext.BaseDirectory}");
|
|
|
|
|
foreach (var name in Directory.GetFiles(AppContext.BaseDirectory, "*.*",
|
|
|
|
|
SearchOption.AllDirectories).Where(f =>Path.GetExtension(f).ToLower() == ".xml"))
|
|
|
|
|
{
|
|
|
|
|
option.IncludeXmlComments(name,includeControllerXmlComments:true);
|
2021-01-04 22:17:49 +08:00
|
|
|
|
// logger.LogInformation($"find api file{name}");
|
2020-10-22 14:59:36 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
option.OperationFilter<GlobalHttpHeaderOperationFilter>(); // 添加httpHeader参数
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(identityServer))
|
|
|
|
|
{
|
|
|
|
|
//接入identityserver
|
|
|
|
|
option.AddSecurityDefinition("oauth2", new OpenApiSecurityScheme
|
|
|
|
|
{
|
|
|
|
|
Type = SecuritySchemeType.OAuth2,
|
|
|
|
|
Description = "OAuth2登陆授权",
|
|
|
|
|
Flows = new OpenApiOAuthFlows
|
|
|
|
|
{
|
|
|
|
|
Implicit = new OpenApiOAuthFlow
|
|
|
|
|
{
|
|
|
|
|
AuthorizationUrl = new Uri($"{identityServer}/connect/authorize"),
|
|
|
|
|
Scopes = new Dictionary<string, string>
|
|
|
|
|
{
|
|
|
|
|
{ "openauthapi", "同意openauth.webapi 的访问权限" }//指定客户端请求的api作用域。 如果为空,则客户端无法访问
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
option.OperationFilter<AuthResponsesOperationFilter>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
services.Configure<AppSetting>(Configuration.GetSection("AppSetting"));
|
|
|
|
|
services.AddControllers(option =>
|
|
|
|
|
{
|
|
|
|
|
option.Filters.Add< OpenAuthFilter>();
|
|
|
|
|
}).AddNewtonsoftJson(options =>
|
|
|
|
|
{
|
|
|
|
|
//忽略循环引用
|
|
|
|
|
options.SerializerSettings.ReferenceLoopHandling = ReferenceLoopHandling.Ignore;
|
|
|
|
|
//不使用驼峰样式的key
|
|
|
|
|
//options.SerializerSettings.ContractResolver = new DefaultContractResolver();
|
|
|
|
|
options.SerializerSettings.DateFormatString = "yyyy-MM-dd HH:mm:ss";
|
|
|
|
|
});
|
|
|
|
|
services.AddMemoryCache();
|
|
|
|
|
services.AddCors();
|
|
|
|
|
// todo:如果正式 环境请用下面的方式限制随意访问跨域
|
|
|
|
|
// var origins = new []
|
|
|
|
|
// {
|
|
|
|
|
// "http://localhost:1803",
|
|
|
|
|
// "http://localhost:52789"
|
|
|
|
|
// };
|
|
|
|
|
// if (Environment.IsProduction())
|
|
|
|
|
// {
|
|
|
|
|
// origins = new []
|
|
|
|
|
// {
|
|
|
|
|
// "http://demo.openauth.me:1803",
|
|
|
|
|
// "http://demo.openauth.me:52789"
|
|
|
|
|
// };
|
|
|
|
|
// }
|
|
|
|
|
// services.AddCors(option=>option.AddPolicy("cors", policy =>
|
|
|
|
|
// policy.AllowAnyHeader().AllowAnyMethod().AllowCredentials().WithOrigins(origins)));
|
2021-01-27 13:42:38 +08:00
|
|
|
|
|
2020-10-22 14:59:36 +08:00
|
|
|
|
//在startup里面只能通过这种方式获取到appsettings里面的值,不能用IOptions😰
|
2021-04-21 18:02:01 +08:00
|
|
|
|
var dbtypes = ((ConfigurationSection)Configuration.GetSection("AppSetting:DbTypes")).GetChildren()
|
|
|
|
|
.ToDictionary(x => x.Key, x => x.Value);
|
2021-01-04 22:17:49 +08:00
|
|
|
|
var connectionString = Configuration.GetConnectionString("OpenAuthDBContext");
|
2021-04-21 18:02:01 +08:00
|
|
|
|
logger.LogInformation($"系统配置的数据库类型:{JsonHelper.Instance.Serialize(dbtypes)},连接字符串:{connectionString}");
|
2021-01-27 13:42:38 +08:00
|
|
|
|
services.AddDbContext<OpenAuthDBContext>();
|
2020-10-22 14:59:36 +08:00
|
|
|
|
|
|
|
|
|
services.AddHttpClient();
|
|
|
|
|
|
|
|
|
|
services.AddDataProtection().PersistKeysToFileSystem(new DirectoryInfo(Configuration["DataProtection"]));
|
|
|
|
|
|
|
|
|
|
//设置定时启动的任务
|
|
|
|
|
services.AddHostedService<QuartzService>();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void ConfigureContainer(ContainerBuilder builder)
|
|
|
|
|
{
|
|
|
|
|
AutofacExt.InitAutofac(builder);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
|
2020-12-27 00:00:28 +08:00
|
|
|
|
public void Configure(IApplicationBuilder app, IHostEnvironment env, ILoggerFactory loggerFactory)
|
2020-10-22 14:59:36 +08:00
|
|
|
|
{
|
2020-12-27 00:00:28 +08:00
|
|
|
|
loggerFactory.AddLog4Net();
|
|
|
|
|
|
2020-10-22 14:59:36 +08:00
|
|
|
|
if (env.IsDevelopment())
|
|
|
|
|
{
|
|
|
|
|
app.UseDeveloperExceptionPage();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//可以访问根目录下面的静态文件
|
2021-04-06 10:21:05 +08:00
|
|
|
|
var staticfile = new StaticFileOptions
|
|
|
|
|
{
|
|
|
|
|
FileProvider = new PhysicalFileProvider(AppContext.BaseDirectory),
|
|
|
|
|
OnPrepareResponse = (ctx) =>
|
|
|
|
|
{
|
|
|
|
|
//可以在这里为静态文件添加其他http头信息,默认添加跨域信息
|
|
|
|
|
ctx.Context.Response.Headers["Access-Control-Allow-Origin"] = "*";
|
|
|
|
|
}
|
|
|
|
|
};
|
2020-10-22 14:59:36 +08:00
|
|
|
|
app.UseStaticFiles(staticfile);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//todo:测试可以允许任意跨域,正式环境要加权限
|
|
|
|
|
app.UseCors(builder => builder.AllowAnyOrigin()
|
|
|
|
|
.AllowAnyMethod()
|
|
|
|
|
.AllowAnyHeader());
|
|
|
|
|
|
|
|
|
|
app.UseRouting();
|
|
|
|
|
app.UseAuthentication();
|
|
|
|
|
|
|
|
|
|
app.UseEndpoints(endpoints =>
|
|
|
|
|
{
|
|
|
|
|
endpoints.MapControllers();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
//配置ServiceProvider
|
|
|
|
|
AutofacContainerModule.ConfigServiceProvider(app.ApplicationServices);
|
|
|
|
|
|
|
|
|
|
app.UseSwagger();
|
|
|
|
|
|
|
|
|
|
// Enable middleware to serve swagger-ui (HTML, JS, CSS, etc.),
|
|
|
|
|
// specifying the Swagger JSON endpoint.
|
|
|
|
|
app.UseSwaggerUI(c =>
|
|
|
|
|
{
|
|
|
|
|
c.SwaggerEndpoint("/swagger/v1/swagger.json", "V1 Docs");
|
|
|
|
|
c.DocExpansion(DocExpansion.None);
|
|
|
|
|
c.OAuthClientId("OpenAuth.WebApi"); //oauth客户端名称
|
|
|
|
|
c.OAuthAppName("开源版webapi认证"); // 描述
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|