1. 程式人生 > >ASP.Net Core 2.2使用SQLite資料庫unable to open database file

ASP.Net Core 2.2使用SQLite資料庫unable to open database file

原文: ASP.Net Core 2.2使用SQLite資料庫unable to open database file

最近把專案更新到了ASP.Net Core 2.2,釋出之後發現在IIS下使用SQLite資料庫不行了,報異常說不能開啟資料庫。"unable to open database file",奇了個怪了。照理說這個不是許可權就是路徑錯了,許可權直接加了Everyone也無濟於事,後來換成絕對路徑就可以了,那說明確實是路徑錯了。

但是寫的相對路徑肯定是沒錯的,使用 dotnet 命令來執行也是正常的, dotnet ZKEACMS.WebHost.dll。

ConnectionString

"ConnectionString": "Data Source=Database.sqlite"

後來想起了之前有看過的這篇令人激動的文章:

就是2.2可以使用In Process的託管模式,說效能有驚天地泣鬼神的提升,就想說會不會是這玩意的問題,畢竟當初升級時也是我主動改的這個:

<Project Sdk="Microsoft.NET.Sdk.Web">
  <PropertyGroup>
    <AspNetCoreHostingModel>InProcess</AspNetCoreHostingModel>
  </PropertyGroup>
</Project>

於是我改了一下web.config,切換成使用舊的模式: modules="AspNetCoreModuleV2" -> modules="AspNetCoreModule",然後程式就正常運行了。

妥妥的寫個issue給微軟:https://github.com/aspnet/AspNetCore/issues/6117

我再使用In Process的託管模式做了一下debug,看到了令人驚奇的結果,這個當前目錄竟然變成了IIS的目錄,難怪相對路徑錯了。

解決方式

主動設定一下當前目錄為程式根目錄:

System.IO.Directory.SetCurrentDirectory(hostingEnvironment.ContentRootPath);