From 978a7461a4ab2e64f08ff8aa3ab213b7b49f7592 Mon Sep 17 00:00:00 2001
From: Luke Latham <1622880+guardrex@users.noreply.github.com>
Date: Thu, 14 Mar 2024 09:14:17 -0400
Subject: [PATCH] Static files article updates (#32060)
---
.../blazor/fundamentals/static-files.md | 51 ++++++++++++++-----
1 file changed, 37 insertions(+), 14 deletions(-)
diff --git a/aspnetcore/blazor/fundamentals/static-files.md b/aspnetcore/blazor/fundamentals/static-files.md
index 3d7838a190..2b8adef238 100644
--- a/aspnetcore/blazor/fundamentals/static-files.md
+++ b/aspnetcore/blazor/fundamentals/static-files.md
@@ -16,12 +16,18 @@ This article describes Blazor app configuration for serving static files.
:::moniker range=">= aspnetcore-8.0"
+## Blazor framework static files
+
+In releases prior to .NET 8, Blazor framework static files, such as the Blazor script, are served via Static File Middleware. In .NET 8 or later, Blazor framework static files are mapped using endpoint routing, and Static File Middleware is no longer used.
+
## Static Web Asset Project Mode
*This section applies to the `.Client` project of a Blazor Web App.*
The required `Default` setting in the `.Client` project of a Blazor Web App reverts Blazor WebAssembly static asset behaviors back to the defaults, so that the project behaves as part of the hosted project. The Blazor WebAssembly SDK (`Microsoft.NET.Sdk.BlazorWebAssembly`) configures static web assets in a specific way to work in "standalone" mode with a server simply consuming the outputs from the library. This isn't appropriate for a Blazor Web App, where the WebAssembly portion of the app is a logical part of the host and must behave more like a library. For example, the project doesn't expose the styles bundle (for example, `BlazorSample.Client.styles.css`) and instead only provides the host with the project bundle, so that the host can include it in its own styles bundle.
+Changing the value (`Default`) of `` or removing the property from the `.Client` project is ***not*** supported.
+
:::moniker-end
## Static File Middleware
@@ -152,6 +158,37 @@ In the preceding examples, the `{TFM}` placeholder is the [Target Framework Moni
*This section applies to server-side static files.*
+:::moniker range=">= aspnetcore-8.0"
+
+To create additional file mappings with a or configure other , use **one** of the following approaches. In the following examples, the `{EXTENSION}` placeholder is the file extension, and the `{CONTENT TYPE}` placeholder is the content type. The namespace for the following API is .
+
+* Configure options through [dependency injection (DI)](xref:blazor/fundamentals/dependency-injection) in the `Program` file using :
+
+ ```csharp
+ var provider = new FileExtensionContentTypeProvider();
+ provider.Mappings["{EXTENSION}"] = "{CONTENT TYPE}";
+
+ builder.Services.Configure(options =>
+ {
+ options.ContentTypeProvider = provider;
+ });
+
+ app.UseStaticFiles();
+ ```
+
+* Pass the directly to in the `Program` file:
+
+ ```csharp
+ var provider = new FileExtensionContentTypeProvider();
+ provider.Mappings["{EXTENSION}"] = "{CONTENT TYPE}";
+
+ app.UseStaticFiles(new StaticFileOptions { ContentTypeProvider = provider });
+ ```
+
+:::moniker-end
+
+:::moniker range="< aspnetcore-8.0"
+
To create additional file mappings with a or configure other , use **one** of the following approaches. In the following examples, the `{EXTENSION}` placeholder is the file extension, and the `{CONTENT TYPE}` placeholder is the content type.
* Configure options through [dependency injection (DI)](xref:blazor/fundamentals/dependency-injection) in the `Program` file using :
@@ -188,20 +225,6 @@ To create additional file mappings with a to execute a custom Static File Middleware:
-
- ```csharp
- app.MapWhen(ctx => !ctx.Request.Path
- .StartsWithSegments("/_framework/blazor.web.js"),
- subApp => subApp.UseStaticFiles(new StaticFileOptions() { ... }));
- ```
-
-:::moniker-end
-
-:::moniker range="< aspnetcore-8.0"
-
* You can avoid interfering with serving `_framework/blazor.server.js` by using to execute a custom Static File Middleware:
```csharp