0

0

Blazor 怎么在不同环境下使用不同配置

月夜之吻

月夜之吻

发布时间:2025-12-24 11:04:03

|

609人浏览过

|

来源于php中文网

原创

Blazor应用按环境配置分Server与WASM两类:Server沿用ASP.NET Core机制,自动加载appsettings.{Environment}.json;WASM需手动AddJsonFile并注入环境名,敏感配置须后端提供。

blazor 怎么在不同环境下使用不同配置

Blazor 应用在不同环境(如开发、测试、生产)中使用不同配置,核心思路和 ASP.NET Core 一致:依靠 环境变量ASPNETCORE_ENVIRONMENT) + 分环境的配置文件appsettings.{Environment}.json),并结合 Blazor 的启动逻辑加载对应配置。

服务端渲染(Blazor Server)直接沿用 ASP.NET Core 配置机制

Blazor Server 是标准的 ASP.NET Core 应用,配置方式完全相同:

  • 项目根目录下保留 appsettings.json(通用配置)和 appsettings.Development.jsonappsettings.Production.json 等环境专属文件
  • 确保这些文件的 “复制到输出目录”属性设为“如果较新则复制”
  • Program.cs 中调用 builder.Configuration 加载配置,无需额外操作 —— 框架会自动根据 ASPNETCORE_ENVIRONMENT 值合并对应文件
  • 例如,在开发环境下运行时,appsettings.Development.json 会自动覆盖 appsettings.json 中的同名键

WebAssembly(Blazor WASM)需手动加载环境配置文件

Blazor WASM 运行在浏览器中,没有服务器端环境变量,也不能直接读取本地文件系统。它通过 HTTP 请求加载 JSON 配置,因此要按环境区分,关键在于:

  • 构建时生成对应环境的 appsettings.{Environment}.json 文件(如 appsettings.Staging.json)并部署到服务器同一目录下
  • Program.cs 中显式调用 configuration.AddJsonFile 并传入带环境名的路径
  • 环境名通常由构建参数或部署脚本控制,比如用 MSBuild 属性 $(Configuration) 或自定义变量

示例(WASM 的 Program.cs):

Kuwebs企业网站管理系统3.1.5 UTF8
Kuwebs企业网站管理系统3.1.5 UTF8

酷纬企业网站管理系统Kuwebs是酷纬信息开发的为企业网站提供解决方案而开发的营销型网站系统。在线留言模块、常见问题模块、友情链接模块。前台采用DIV+CSS,遵循SEO标准。 1.支持中文、英文两种版本,后台可以在不同的环境下编辑中英文。 3.程序和界面分离,提供通用的PHP标准语法字段供前台调用,可以为不同的页面设置不同的风格。 5.支持google地图生成、自定义标题、自定义关键词、自定义描

下载
// 假设通过构建参数传入环境名,例如:dotnet publish -c Release -p:BlazorEnvironment=Staging var builder = WebAssemblyHostBuilder.CreateDefault(args); var environment = builder.HostEnvironment.Environment; // 默认是 "Production",也可从 JS 或 URL 参数注入 builder.Configuration.AddJsonFile($"appsettings.{environment}.json", optional: true, reloadOnChange: true);

统一管理环境标识:避免硬编码环境名

硬写 "Development""Production" 容易出错。推荐做法:

  • Blazor Server:依赖 IWebHostEnvironment.Environment(已内置)
  • Blazor WASM:通过 WebAssemblyHostBuilder.HostEnvironment.Environment 获取(默认由 index.html 中的 window["blazor-environment"] 或构建时注入的 __env 决定)
  • 更可靠的方式是在发布前,用构建脚本(如 GitHub Actions、Azure DevOps 或 MSBuild Target)向 index.html 注入环境标识,或通过 JS interop 读取 location.hostname 映射环境(例如 dev.example.com → Development

敏感配置不放 appsettings.json,用环境变量或密钥管理器

数据库连接字符串、API 密钥等不应提交到代码库:

  • Blazor Server:用 dotnet user-secrets(开发)或操作系统级环境变量(生产)替代 JSON 中的敏感项
  • Blazor WASM:切勿在客户端存储敏感配置 —— 所有密钥必须由后端 API 提供,前端只持 Token 或临时凭证
  • 若 WASM 需要调用不同环境的后端地址,可将 API 基地址作为公开配置(如 ApiBaseUri)放在 appsettings.{env}.json 中,这是安全且常见的做法

基本上就这些。关键是分清 Blazor Server 和 WASM 的运行模型差异:Server 走标准 .NET 配置管道,WASM 则靠前端资源加载 + 构建时/运行时注入环境上下文。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

400

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

305

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

67

2025.09.10

html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

581

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

635

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

455

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.08.01

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.5万人学习

AngularJS教程
AngularJS教程

共24课时 | 2万人学习

CSS教程
CSS教程

共754课时 | 16.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号