TLDR
以前工作(以前的版本)推送到Azure现在提供了非描述性错误500,但在两台不同的本地PC上运行没有问题。我无法确定原因并希望得到一些帮助。
详情
我有一个我一直在开发的ASP.NET核心Web应用程序。该应用程序在本地运行没有问题(以及在我从我的私人git克隆项目的另一台PC上。)
但是,我发布到我的Azure网络应用程序(几个月前我用之前的版本做过的事情),现在它失败了(这是一个新创建的Web应用程序实例。)我返回了一个相当普通的错误500页,当我尝试查看该应用...
我在阅读this并在天蓝色的门户网站中挖掘后终于检查了日志流,并返回了一个包含更多信息的错误页面,但仍然没有任何实用性。
受到this SO answer的启发,我在Azure“应用程序设置”刀片中将我的环境标志(ASPNETCORE_ENVIRONMENT
)切换为Development
并给了它一个镜头(所以我可以看到结果。 )我犹豫是否这样做因为我的sql连接字符串在那里并且因环境而异(dev是本地的,prod是azure sql)所以我保证在某个时候出现错误(当它试图命中数据库时。)在app.UseDeveloperExceptionPage()
方法中通过Configure
向我提供了一条非常有用且奇怪的错误消息...
声称我的appsettings.Development.json
不存在!究竟怎么没有在发布推动中做到这一点?!
Startup.cs的相关行......
public Startup(IHostingEnvironment env) {
var builder = new ConfigurationBuilder()
.SetBasePath(env.ContentRootPath)
.AddJsonFile("appsettings.json")
.AddJsonFile($"appsettings.{env.EnvironmentName}.json")
.AddEnvironmentVariables();
Configuration = builder.Build();
} // LINE 41 reported
FTP到/ site / wwwroot我看到文件实际上并不存在(但通用和生产的文件都是。)当你选择Release或Debug时,VS会以某种方式过滤这些或设置环境变量进行打包吗?我没有在包/发布日志中看到任何迹象。
因此,我将环境变量切换回“生产”并从“概述”刀片重新启动了Web应用程序(以防万一。)然后我将app.UseDeveloperExceptionPage
行移出了if (env.IsDevelopment()) {
阻止(所以它始终可用。)构建,重新发布(保持“删除目的地中的其他文件”框暂时检查,删除所需的时间更长,然后推送所有内容,但更安全),并刷新页面,我' m再次回到通用错误500消息(没有其他细节)......
我知道customErrors
is no longer relevant,作为我之前看到UseDeveloperExceptionPage
的结果的证据。此外,我已启用“详细错误消息”...
我到底在想什么?!
EDIT1:在launchSettings.json
中将我的本地dev env标志设置为“Production”...
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Production"
}
......一切都还行不错!然而,Azure上的错误仍为500!
EDIT2:
我意识到为什么appsettings.Development.json
没有发布,它不在project.json
的{{1}}部分......
publishInclude
...仍然不清楚为什么,在环境检查之外移动 "publishOptions": {
"include": [
"wwwroot",
"Views",
"appsettings.json",
"appsettings.Production.json",
"web.config"
]
},
之后,我无法看到开发人员异常页面。但现在我意识到可能还有其他丢失的文件没有发布(无论环境如何!)
答案 0 :(得分:0)
publishOptions
不包括应用所需的所有.json
个文件......呃。