转换文件编码

This commit is contained in:
不做码农 2022-06-01 17:25:41 +08:00
parent 3b8ec3cc95
commit b4dceca92f
3 changed files with 70 additions and 70 deletions

View File

@ -1,21 +1,21 @@
FROM mcr.microsoft.com/dotnet/aspnet:5.0 AS base
#创建 /app文件夹
#创建 /app文件夹
WORKDIR /app
#创建挂载目录,用于将程序部署在服务器本地
#创建挂载目录,用于将程序部署在服务器本地
#VOLUME /app
#设置docker容器对外暴露端口
#设置docker容器对外暴露端口
EXPOSE 8888
VOLUME /app/logs
#COPY bin/Release/net5.0/publish/ app/
COPY . app/
#设置容器内的时区如果不设置默认时区是标准时间比北京时间晚8个小时
#设置容器内的时区如果不设置默认时区是标准时间比北京时间晚8个小时
RUN echo "Asia/shanghai" > /etc/timezone
RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
# 复制发布文件到工作目录
# 复制发布文件到工作目录
#COPY . app/
WORKDIR /app
#等价于 dotnet ZR.Admin.WebApi.dll如果不指定启动端口默认在docker里面启动端口是80端口
#等价于 dotnet ZR.Admin.WebApi.dll如果不指定启动端口默认在docker里面启动端口是80端口
ENTRYPOINT ["dotnet", "ZR.Admin.WebApi.dll", "--server.urls","http://*:8888"]

View File

@ -33,39 +33,39 @@ namespace ZR.Admin.WebApi
{
string corsUrls = Configuration["corsUrls"];
//配置跨域
//配置跨域
services.AddCors(c =>
{
c.AddPolicy("Policy", policy =>
{
policy.WithOrigins(corsUrls.Split(',', StringSplitOptions.RemoveEmptyEntries))
.AllowAnyHeader()//允许任意头
.AllowCredentials()//允许cookie
.AllowAnyMethod();//允许任意方法
.AllowAnyHeader()//允许任意头
.AllowCredentials()//允许cookie
.AllowAnyMethod();//允许任意方法
});
});
//注入SignalR实时通讯默认用json传输
//注入SignalR实时通讯默认用json传输
services.AddSignalR(options =>
{
//客户端发保持连接请求到服务端最长间隔默认30秒改成4分钟网页需跟着设置connection.keepAliveIntervalInMilliseconds = 12e4;即2分钟
//客户端发保持连接请求到服务端最长间隔默认30秒改成4分钟网页需跟着设置connection.keepAliveIntervalInMilliseconds = 12e4;即2分钟
//options.ClientTimeoutInterval = TimeSpan.FromMinutes(4);
//服务端发保持连接请求到客户端间隔默认15秒改成2分钟网页需跟着设置connection.serverTimeoutInMilliseconds = 24e4;即4分钟
//服务端发保持连接请求到客户端间隔默认15秒改成2分钟网页需跟着设置connection.serverTimeoutInMilliseconds = 24e4;即4分钟
//options.KeepAliveInterval = TimeSpan.FromMinutes(2);
});
//消除Error unprotecting the session cookie警告
//消除Error unprotecting the session cookie警告
services.AddDataProtection()
.PersistKeysToFileSystem(new DirectoryInfo(Directory.GetCurrentDirectory() + Path.DirectorySeparatorChar + "DataProtection"));
//普通验证码
//普通验证码
services.AddHeiCaptcha();
services.AddIPRate(Configuration);
services.AddSession();
services.AddMemoryCache();
services.AddHttpContextAccessor();
//绑定整个对象到Model上
//绑定整个对象到Model上
services.Configure<OptionsSetting>(Configuration);
//jwt 认证
//jwt 认证
services.AddAuthentication(options =>
{
options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
@ -80,7 +80,7 @@ namespace ZR.Admin.WebApi
services.AddMvc(options =>
{
options.Filters.Add(typeof(GlobalActionMonitor));//全局注册
options.Filters.Add(typeof(GlobalActionMonitor));//全局注册
})
.AddJsonOptions(options =>
{
@ -99,7 +99,7 @@ namespace ZR.Admin.WebApi
app.UseDeveloperExceptionPage();
}
app.UseSwagger();
//使可以多次多去body内容
//使可以多次多去body内容
app.Use((context, next) =>
{
context.Request.EnableBuffering();
@ -109,33 +109,33 @@ namespace ZR.Admin.WebApi
}
return next();
});
//开启访问静态文件/wwwroot目录文件要放在UseRouting前面
//开启访问静态文件/wwwroot目录文件要放在UseRouting前面
app.UseStaticFiles();
//开启路由访问
//开启路由访问
app.UseRouting();
app.UseCors("Policy");//要放在app.UseEndpoints前。
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会启用Authentication中间件该中间件会根据当前Http请求中的Cookie信息来设置HttpContext.User属性后面会用到
//所以只有在app.UseAuthentication方法之后注册的中间件才能够从HttpContext.User中读取到值
//这也是为什么上面强调app.UseAuthentication方法一定要放在下面的app.UseMvc方法前面因为只有这样ASP.NET Core的MVC中间件中才能读取到HttpContext.User的值。
//1.先开启认证
app.UseAuthentication();
//2.再开启授权
//2.再开启授权
app.UseAuthorization();
//开启session
//开启session
//app.UseSession();
//开启缓存
//开启缓存
app.UseResponseCaching();
//恢复/启动任务
//恢复/启动任务
app.UseAddTaskSchedulers();
//使用全局异常中间件
//使用全局异常中间件
app.UseMiddleware<GlobalExceptionMiddleware>();
//启用客户端IP限制速率
//启用客户端IP限制速率
app.UseIpRateLimiting();
app.UseEndpoints(endpoints =>
{
//设置socket连接
//设置socket连接
endpoints.MapHub<MessageHub>("/msgHub");
endpoints.MapControllerRoute(
@ -145,7 +145,7 @@ namespace ZR.Admin.WebApi
}
/// <summary>
/// 注册Services服务
/// 注册Services服务
/// </summary>
/// <param name="services"></param>
/// <param name="configuration"></param>
@ -153,12 +153,12 @@ namespace ZR.Admin.WebApi
{
services.AddAppService();
services.AddSingleton(new AppSettings(configuration));
//开启计划任务
//开启计划任务
services.AddTaskSchedulers();
//初始化db
//初始化db
DbExtension.AddDb(configuration);
//注册REDIS 服务
//注册REDIS 服务
Task.Run(() =>
{
//RedisServer.Initalize();

View File

@ -7,97 +7,97 @@
}
},
"ConnectionStrings": {
"conn_db": "Data Source=LAPTOP-STKF2M8H\\SQLEXPRESS;User ID=sa;Password=zradmin123;Initial Catalog=ZrAdmin;Integrated Security=SSPI", //
"conn_db_type": "1" // MySql = 0, SqlServer = 1
"conn_db": "Data Source=LAPTOP-STKF2M8H\\SQLEXPRESS;User ID=sa;Password=zradmin123;Initial Catalog=ZrAdmin;Integrated Security=SSPI", //
"conn_db_type": "1" // MySql = 0, SqlServer = 1
},
"urls": "http://localhost:8888", //urldevServer
"corsUrls": "http://localhost:8887", //","
"urls": "http://localhost:8888", //urldevServer
"corsUrls": "http://localhost:8887", //","
"JwtSettings": {
"Issuer": "ZRAdmin.NET",
"Audience": "ZRAdmin.NET",
"SecretKey": "SecretKey-ZRADMIN.NET-20210101",
"Expire": 1440 //jwt
"Expire": 1440 //jwt
},
"DemoMode": false, //
"DemoMode": false, //
"Upload": {
"UploadUrl": "http://localhost:8888",
"localSavePath": "" ///home/website/uploads
"localSavePath": "" ///home/website/uploads
},
//
//
"ALIYUN_OSS": {
"REGIONID": "cn-hangzhou",
"KEY": "XX",
"SECRET": "XX",
"bucketName": "bucketName",
"domainUrl": "http://xxx.xxx.com" //访
"domainUrl": "http://xxx.xxx.com" //访
},
"gen": {
"conn": "Data Source=LAPTOP-STKF2M8H\\SQLEXPRESS;User ID=sa;Password=zradmin123;Initial Catalog=ZrAdmin;Integrated Security=SSPI",
"dbType": 1, //MySql = 0, SqlServer = 1
"autoPre": true, //
"autoPre": true, //
"author": "admin",
"tablePrefix": "sys_", //"表前缀(生成类名不会包含表前缀,多个用逗号分隔)",
"vuePath": "" //egD:\Work\ZRAdmin-Vue3
"tablePrefix": "sys_", //"表前缀(生成类名不会包含表前缀,多个用逗号分隔)",
"vuePath": "" //egD:\Work\ZRAdmin-Vue3
},
//
//
"MailOptions": {
//
"From": "", //egxxxx@qq.com
//
//
"From": "", //egxxxx@qq.com
//
"Password": "123456",
//
//
"Smtp": "smtp.qq.com",
"Port": 587
},
//redis
//redis
"RedisServer": {
"Cache": "127.0.0.1:6379,defaultDatabase=0,poolsize=50,ssl=false,writeBuffer=10240,prefix=cache:",
"Session": "127.0.0.1:6379,defaultDatabase=0,poolsize=50,ssl=false,writeBuffer=10240,prefix=session:"
},
//
//
"IpRateLimiting": {
//5访False访5访
//True5GetData访访PostData()5,5
//5访False访5访
//True5GetData访访PostData()5,5
"EnableEndpointRateLimiting": true,
//falseAPI; 3APIAPI
//StackBlockedRequeststrue
//falseAPI; 3APIAPI
//StackBlockedRequeststrue
"StackBlockedRequests": false,
"RealIpHeader": "X-Real-IP",
//IDIDClientWhitelist
//IDIDClientWhitelist
"ClientIdHeader": "X-ClientId",
"HttpStatusCode": 429,
//
//
"EndpointWhitelist": [ "post:/system/dict/data/types", "*:/msghub/negotiate", "*:/LogOut" ],
//
//
//"ClientWhitelist": [ "dev-id-1", "dev-id-2" ],
"QuotaExceededResponse": {
"Content": "{{\"code\":429,\"msg\":\"访问过于频繁,请稍后重试\"}}",
"Content": "{{\"code\":429,\"msg\":\"访问过于频繁,请稍后重试\"}}",
"ContentType": "application/json",
"StatusCode": 429
},
//api,*
//api,*
"GeneralRules": [
{
"Endpoint": "*:/captchaImage",
//{}{}使s, m, h, d
//{}{}使s, m, h, d
"Period": "3s",
"Limit": 5
},
{
"Endpoint": "post:*",
//{}{}使s, m, h, d
//{}{}使s, m, h, d
"Period": "3s",
"Limit": 1
},
{
"Endpoint": "put:*",
//{}{}使s, m, h, d
//{}{}使s, m, h, d
"Period": "3s",
"Limit": 1
}
//{
// "Endpoint": "*",
// //{}{}使s, m, h, d
// //{}{}使s, m, h, d
// "Period": "1s",
// "Limit": 2
//}
@ -118,7 +118,7 @@
//}
],
"IpRateLimitPolicies": {
//ip
//ip
"IpRules": [
]
}