news 2026/4/23 0:38:24

Blazor Web App 在 IIS 部署的基路径设置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Blazor Web App 在 IIS 部署的基路径设置

引言

在使用 Blazor Web App 进行开发时,部署到 IIS 服务器是一个常见的选择。然而,许多开发者在部署过程中可能会遇到一些配置问题,特别是在处理基路径(Base Path)设置时。本文将详细介绍如何正确设置 Blazor Web App 的基路径,以解决在 IIS 下的部署问题。

实例背景

假设你使用 Visual Studio 2022 V17.8.2 创建了一个 Blazor Web App,并使用 Web Deploy 方式发布到 IIS 服务器上。你的应用发布在Default Web Site下的blazortest80目录中。

示例代码

program.cs
usingBlazorWebAppNet8.Components;varbuilder=WebApplication.CreateBuilder(args);// 添加服务到容器builder.Services.AddRazorComponents().AddInteractiveServerComponents();varapp=builder.Build();// 配置 HTTP 请求管道if(!app.Environment.IsDevelopment()){app.UseExceptionHandler("/Error",createScopeForErrors:true);// 默认 HSTS 值为 30 天。生产环境可能需要调整app.UseHsts();}app.UseHttpsRedirection();app.UseStaticFiles();app.UseAntiforgery();// 设置基路径app.UsePathBase("/blazortest80");app.MapRazorComponents<App>().AddInteractiveServerRenderMode();app.Run();
App.razor
<!DOCTYPEhtml><htmllang="en"><head><metacharset="utf-8"/><metaname="viewport"content="width=device-width, initial-scale=1.0"/><!-- 设置基路径 --><basehref="/blazortest80/"/><linkrel="stylesheet"href="bootstrap/bootstrap.min.css"/><linkrel="stylesheet"href="app.css"/><linkrel="stylesheet"href="BlazorWebAppNet8.styles.css"/><linkrel="icon"type="image/png"href="favicon.png"/><HeadOutlet/></head><body><Routes/><scriptsrc="_framework/blazor.web.js"></script></body></html>

问题描述

当你试图通过https://testserver.de/blazortest80访问应用时,可能会遇到页面无法加载的问题。这是因为 Blazor 应用需要正确的基路径来处理相对路径的导航。

解决方案

  1. program.cs中设置UsePathBase:

    • 添加app.UsePathBase("/blazortest80");以告知应用其基路径。
  2. App.razor中设置base标签:

    • 修改<base href="/" /><base href="/blazortest80/" />

这两个步骤确保了应用能够正确处理路径,避免了在 IIS 下的导航问题。

注意事项

  • 如果你只设置了app.UsePathBase("/blazortest80");,访问应用时需要在 URL 末尾添加一个斜杠(/),如https://testserver.de/blazortest80/
  • 如果你同时设置了base标签和UsePathBase,则可以省略 URL 末尾的斜杠。

总结

通过正确设置基路径,Blazor Web App 在 IIS 下的部署可以顺利进行。开发者需要在program.cs中使用UsePathBase,并在App.razor中设置base标签,以确保应用能够正确处理导航和资源请求。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 4:24:00

避免常见错误:Allegro Gerber导出注意事项全面讲解

Allegro导出Gerber文件避坑指南&#xff1a;从配置到交付的全流程实战解析在PCB设计的世界里&#xff0c;完成布局布线只是“万里长征走完第一步”。真正决定产品能否顺利投产的关键一步——Allegro导出Gerber文件&#xff0c;往往被许多工程师轻视或误操作&#xff0c;最终导致…

作者头像 李华
网站建设 2026/4/21 23:33:27

USB-Serial Controller D通信协议核心要点

从开发板到工业现场&#xff1a;深入理解 USB-Serial Controller D 的通信机制与实战设计你有没有遇到过这样的场景&#xff1f;调试一个全新的嵌入式板子&#xff0c;串口线一接上电脑&#xff0c;设备管理器里却“找不到COM口”&#xff1b;或者好不容易识别了&#xff0c;数…

作者头像 李华
网站建设 2026/4/20 16:27:18

校平机的工程悖论:快、准、省的三角博弈

所有工业设备都面临一个不可能三角——速度、精度、成本三者无法同时极致。校平机将这个矛盾展现得尤为赤裸&#xff1a;想快&#xff1f;精度必然牺牲&#xff1b;要准&#xff1f;速度就得妥协&#xff1b;既快又准&#xff1f;成本指数级上升。理解这个三角博弈&#xff0c;…

作者头像 李华
网站建设 2026/4/17 0:28:10

USB转232驱动安装兼容性调试技巧

USB转232驱动调试实战&#xff1a;从CH340到FTDI的全栈避坑指南 你有没有遇到过这样的场景&#xff1f;现场调试PLC&#xff0c;插上USB转232线&#xff0c;设备管理器里却显示“未知设备”&#xff1b;或者好不容易识别出COM口&#xff0c;刚连上几秒就断开&#xff0c;数据还…

作者头像 李华
网站建设 2026/4/17 5:40:04

易连说-如何寻找具备 Drummond Group AS2 国际认证的EDI 产品?

在数字化供应链重构的浪潮中&#xff0c;电子数据交换&#xff08;EDI&#xff09;已从“可选配置”升级为企业对接全球贸易伙伴的“必备能力”。作为 EDI 数据传输的主流协议——AS2 协议凭借安全加密、可靠传输的特性&#xff0c;成为企业间数据交换的核心选择&#xff0c;选…

作者头像 李华
网站建设 2026/4/21 4:48:26

电商运营中的数据驱动的决策流程

电商运营中的数据驱动的决策流程关键词&#xff1a;电商运营、数据驱动、决策流程、数据分析、商业智能摘要&#xff1a;本文围绕电商运营中数据驱动的决策流程展开深入探讨。首先介绍了该主题的背景&#xff0c;包括目的、预期读者、文档结构和相关术语。接着阐述了核心概念及…

作者头像 李华