You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
126 lines
4.2 KiB
126 lines
4.2 KiB
using Microsoft.AspNetCore.Authentication.JwtBearer;
|
|
using Microsoft.OpenApi.Models;
|
|
using Newtonsoft.Json.Serialization;
|
|
using QYMessageCenter.Business;
|
|
using QYMessageCenter.Common.Extensions;
|
|
using QYMessageCenter.Common.Http;
|
|
using QYMessageCenter.Common.Log;
|
|
using QYMessageCenter.Common.Models;
|
|
using QYMessageCenter.Filters;
|
|
using QYMessageCenter.Middlewares;
|
|
using QYMessageCenter.Model;
|
|
using System.Reflection;
|
|
using System.Text;
|
|
using Yitter.IdGenerator;
|
|
|
|
var builder = WebApplication.CreateBuilder(args);
|
|
var services = builder.Services;
|
|
var configuration = builder.Configuration;
|
|
|
|
services.AddMemoryCache();
|
|
|
|
var idOption = new IdGeneratorOptions(1);
|
|
var idGenerator = new DefaultIdGenerator(idOption);
|
|
services.AddSingleton(typeof(IIdGenerator), idGenerator);
|
|
var fsql = new FreeSql.FreeSqlBuilder().UseConnectionString(FreeSql.DataType.MySql, configuration.GetConnectionString("DB")).Build();
|
|
services.AddSingleton(typeof(IFreeSql), fsql);
|
|
services.AddSingleton<NLogManager>();
|
|
services.AddSingleton<RestApiService>();
|
|
services.AddSingleton<TaskSchedulerManager>();
|
|
|
|
services.BatchRegisterServices(new Assembly[] { Assembly.Load("QYMessageCenter.Business") }, typeof(IDenpendency));
|
|
services.AddMapper(new MappingProfiles());
|
|
|
|
services.AddHttpContextAccessor();
|
|
services.AddHttpClient();
|
|
services.AddControllers(c =>
|
|
{
|
|
c.Filters.Add<ResultFilter>();
|
|
c.SuppressImplicitRequiredAttributeForNonNullableReferenceTypes = true;
|
|
}).AddNewtonsoftJson(setupAction =>
|
|
{
|
|
setupAction.SerializerSettings.ContractResolver = new DefaultContractResolver();
|
|
setupAction.SerializerSettings.DateFormatString = "yyyy-MM-dd HH:mm:ss";
|
|
//setupAction.SerializerSettings.NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore;
|
|
//setupAction.SerializerSettings.DefaultValueHandling = Newtonsoft.Json.DefaultValueHandling.Include;
|
|
});
|
|
|
|
services.AddCors(options =>
|
|
{
|
|
options.AddPolicy("cors", p =>
|
|
{
|
|
p.AllowAnyOrigin().AllowAnyMethod().AllowAnyHeader();
|
|
});
|
|
});
|
|
|
|
|
|
services.AddEndpointsApiExplorer();
|
|
services.AddSwaggerGen(c =>
|
|
{
|
|
c.SwaggerDoc("v1", new OpenApiInfo
|
|
{
|
|
Version = "v1.0.0",
|
|
Title = "��Խ��Ϣ����API",
|
|
Description = getSWDescription()
|
|
});
|
|
//JWT��֤
|
|
c.AddSecurityDefinition(JwtBearerDefaults.AuthenticationScheme, new OpenApiSecurityScheme
|
|
{
|
|
Scheme = JwtBearerDefaults.AuthenticationScheme,
|
|
BearerFormat = "JWT",
|
|
Type = SecuritySchemeType.ApiKey,
|
|
Name = "Authorization",
|
|
In = ParameterLocation.Header,
|
|
Description = "Authorization:Bearer {your JWT token}<br/>",
|
|
});
|
|
c.AddSecurityRequirement(new OpenApiSecurityRequirement
|
|
{
|
|
{
|
|
new OpenApiSecurityScheme{Reference = new OpenApiReference
|
|
{
|
|
Type = ReferenceType.SecurityScheme,
|
|
Id = JwtBearerDefaults.AuthenticationScheme
|
|
}
|
|
},
|
|
new string[] { }
|
|
}
|
|
});
|
|
|
|
var executingAssembly = Assembly.GetExecutingAssembly();
|
|
var assemblyNames = executingAssembly.GetReferencedAssemblies().Union(new AssemblyName[] { executingAssembly.GetName() }).ToArray();
|
|
Array.ForEach(assemblyNames, (assemblyName) =>
|
|
{
|
|
//var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
|
|
var xmlFile = $"{assemblyName.Name}.xml";
|
|
var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile);
|
|
if (!File.Exists(xmlPath))
|
|
return;
|
|
c.IncludeXmlComments(xmlPath, true);
|
|
});
|
|
});
|
|
|
|
|
|
var app = builder.Build();
|
|
|
|
// Configure the HTTP request pipeline.
|
|
|
|
app.UseSwagger(c => c.SerializeAsV2 = true)
|
|
.UseSwaggerUI(c =>
|
|
{
|
|
c.SwaggerEndpoint("/swagger/v1/swagger.json", "QYMessageCenter API");
|
|
c.RoutePrefix = string.Empty;
|
|
});
|
|
|
|
app.UseMiddleware<CustomExceptionMiddleWare>();
|
|
app.UseRouting();
|
|
app.UseCors("cors");
|
|
app.UseAuthorization();
|
|
app.MapControllers();
|
|
app.Run();
|
|
|
|
|
|
string getSWDescription()
|
|
{
|
|
var filePath = Path.Combine(AppContext.BaseDirectory, "SWDescription.txt");
|
|
return File.ReadAllText(filePath, Encoding.UTF8);
|
|
}
|