你好 @詹 志仁,
首先我先分享下您想要的測試結果。
這裏我需要向您闡述的是,在基於Angular with Asp.net Core項目的模板創建的項目,是前後端分離的,與之前的 SPA 項目的區別是, 原先的前端項目是存放在Asp.net Core項目ClientApp文件夾下的。
所以基於Angular with Asp.net Core項目的模板創建的項目,我們可以看成是獨立的兩個單純的項目,如果沒有進行項目引用的話。 那麽獨立的Asp.net Core項目是前後端分離設計中的Web API項目。 單純創建Web API項目 和這個模板創建的都是一樣的,不包含 wwwroot
文件夾。
這就是爲什麽您提到的,發佈後文件中會有wwwroot文件夾,因爲 我們需要讀取Angualr項目編譯後的靜態文件,從 app.UseStaticFiles(); 中間件我們也可以知道, 這將會默認可以讀取 類似MVC 項目中 wwwroot下的靜態資源文件。 所以這就是發佈后的文件中存在
wwwroot文件夾的原因。 這是默認的行爲。 在這裏,我是非常不推薦您修改成ClientApp/dist的。 這將會破壞一些默認配置,測試時候暫時未遇到。
截圖中的那個 C:\home\site\wwwroot>
路徑是App Service的默認存放 App的路徑,這樣您看起來,就是可以看到在默認路徑下還有一個wwwroot文件夾。 它們的含義是不一樣的, 第一個是App Service 默認讀取發佈文件的路徑, 第二個是Asp.net Core讀取靜態資源的路徑。
您問題中的兩個論壇鏈接中的分享方案,都是我進行測試后編輯它們都是的版本都是基於 小於等於.NET 7.0的,在.NET 8 會有細微的變化,這就是您爲什麽無法正常使它工作的原因。
我不建議您糾結這兩個wwwroot的文件夾,但同時我也會分享如何在.NET 8.0中實現此需求,另外請注意,我暫時沒有找到辦法將ClientApp文件夾下的文件名修改成dist。請查看我的下面的測試代碼和配置。
第一步:修改Program.cs中的靜態資源的中間件
using Microsoft.Extensions.FileProviders;
namespace AngularApp.Server
{
public class Program
{
public static void Main(string[] args)
{
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
var app = builder.Build();
app.UseDefaultFiles();
//app.UseStaticFiles();
// 修改靜態資源的讀取路徑,默認爲發佈後文件的wwwroot文件夾
app.UseStaticFiles(new StaticFileOptions
{
FileProvider = new PhysicalFileProvider(Path.Combine(app.Environment.ContentRootPath, "ClientApp", "angularapp.client", "browser")),
RequestPath = ""
});
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
app.UseSwagger();
app.UseSwaggerUI();
}
app.UseHttpsRedirection();
app.UseAuthorization();
app.MapControllers();
app.MapFallbackToFile("/index.html");
app.Run();
}
}
}
第二步:創建文件夾,否則編譯會遇到文件夾問找到的錯誤訊息
第三步:修改.csproj 文件
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
<Nullable>enable</Nullable>
<ImplicitUsings>enable</ImplicitUsings>
<InvariantGlobalization>true</InvariantGlobalization>
<SpaRoot>..\angularapp.client</SpaRoot>
<SpaProxyLaunchCommand>npm start</SpaProxyLaunchCommand>
<SpaProxyServerUrl>https://localhost:4200</SpaProxyServerUrl>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore.SpaProxy" Version="8.*-*" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.4.0" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\angularapp.client\angularapp.client.esproj">
<ReferenceOutputAssembly>false</ReferenceOutputAssembly>
</ProjectReference>
</ItemGroup>
<ItemGroup>
<Folder Include="ClientApp\angularapp.client\browser\" />
</ItemGroup>
<Target Name="PreBuild" BeforeTargets="PreBuildEvent">
<!-- 確保 Node.js 和 npm 安裝 -->
<Exec Command="node --version" ContinueOnError="true">
<Output TaskParameter="ExitCode" PropertyName="NodeInstalled" />
</Exec>
<Error Condition="'$(NodeInstalled)' != '0'" Text="Node.js is required to build and run this project." />
<!-- 安裝 Angular 應用的依賴 -->
<Exec WorkingDirectory="$(SpaRoot)" Command="npm install" />
</Target>
<Target Name="PublishRunWebpack" AfterTargets="ComputeFilesToPublish">
<!-- 在發佈前構建 Angular 應用 -->
<Exec WorkingDirectory="$(SpaRoot)" Command="npm run build --prod" />
<!-- 確保 Angular 構建的靜態文件被包括在輸出文件中 -->
<ItemGroup>
<DistFiles Include="$(SpaRoot)\dist\**" />
<ResolvedFileToPublish Include="@(DistFiles->'%(FullPath)')">
<RelativePath>ClientApp\%(RecursiveDir)%(FileName)%(Extension)</RelativePath>
<CopyToPublishDirectory>PreserveNewest</CopyToPublishDirectory>
<ExcludeFromSingleFile>true</ExcludeFromSingleFile>
</ResolvedFileToPublish>
</ItemGroup>
</Target>
<Target Name="CleanWwwroot" AfterTargets="Publish">
<!-- 刪除wwwroot文件夾 -->
<Message Text="Deleting wwwroot directory..." Importance="high" />
<Exec Command="rd /s /q $(PublishDir)wwwroot" />
</Target>
</Project>
如果答案是正确的,请点击“接受答案”并点赞。 如果您对此答案还有其他疑问,请点击“评论”。 注意:如果您想接收相关电子邮件,请按照我们的文档中的步骤启用电子邮件通知 此线程的通知。
Best Regards
Jason Pan