全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Blazor WebAssembly怎么调用API Blazor Wasm发起HTTP请求方法

Blazor WebAssembly 调用 API 推荐使用注入的 IHttpClientFactory 和命名 HttpClient,支持配置、拦截与生命周期管理;需配置 CORS、手动处理 Token 认证、错误响应及加载状态。

Blazor WebAssembly 调用 API 主要靠 IHttpClientFactoryHttpClient,推荐用注入的客户端发请求,安全、可配置、支持拦截和生命周期管理。

使用 HttpClient 服务发起 GET 请求

Program.cs 中已默认注册了命名客户端(如 "ServerAPI"),你只需在组件中注入并调用:

  • 确保 Program.cs 里有类似 builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) }); 或更推荐的命名注册:builder.Services.AddHttpClient("ServerAPI", client => client.BaseAddress = new Uri(builder.HostEnvironment.BaseAddress));
  • 组件中用 @inject IHttpClientFactory HttpClientFactory,然后 var client = HttpClientFactory.CreateClient("ServerAPI");
  • 调用 await client.GetFromJsonAsync("api/values"),自动反序列化,简洁安全

POST 请求传参与处理响应

提交数据常用 PostAsJsonAsync,后端接收需匹配模型结构:

  • 定义请求体类,比如 public class LoginRequest { public string Username { get; set; } }
  • 组件中: var response = await client.PostAsJsonAsync("api/auth/login", new LoginRequest { Username = "user" });
  • 检查 response.IsSuccessStatusCode,再用 await response.Content.ReadFromJsonAsync() 解析结果
  • 注意:WASM 运行在浏览器沙箱中,跨域需后端配 CORS,且不能绕过同源策略

错误处理与加载状态控制

真实场景中网络可能失败或延迟,别让 UI 卡住或静默出错:

  • try/catch 捕获 HttpRequestException,区分连接失败、404、500 等
  • 配合 @if (isLoading) { Loading... } 显示加载态
  • 对 401 响应可跳转登录页:if (response.StatusCode == HttpStatusCode.Unauthorized) Navigation.NavigateTo("/login");
  • 避免在 OnInitializedAsync 中直接 await 长耗时请求,建议用 Task.Run 包裹或配合 StateHasChanged() 手动刷新

自定义请求头与认证 Token

带身份凭证调用受保护接口很常见:

  • 从本地存储读取 token:var token = await localStorage.GetItemAsStringAsync("auth_token");(需引用 Microsoft.AspNetCore.Components.Web.Extensions 或用 JS Interop)
  • 设置头:client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", token);
  • 更优雅的做法是用 DelegatingHandler 封装自动加 token 逻辑,注册时链入:AddHttpClient(...).AddHttpMessageHandler();
  • 注意:WASM 无法访问 Cookie(浏览器限制),Token 必须显式传,通常存在 localStorage 或 sessionStorage

基本上就这些。核心是用好 IHttpClientFactory + 异步方法 + 合理错误处理,不复杂但容易忽略加载态和跨域细节。


# js  # json  # cookie  # 浏览器  # session  # 后端  # ai  # microsoft  # nas  # 跨域  # String  # if  # 封装 


相关文章: 如何快速搭建高效可靠的建站解决方案?  常州企业建站如何选择最佳模板?  浅析上传头像示例及其注意事项  网站制作说明怎么写,简述网页设计的流程并说明原因?  建站168自助建站系统:快速模板定制与SEO优化指南  如何基于PHP生成高效IDC网络公司建站源码?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  建站之星在线客服如何快速接入解答?  如何快速搭建高效WAP手机网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  建站之星免费版是否永久可用?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何通过VPS建站无需域名直接访问?  如何打造高效商业网站?建站目的决定转化率  建站主机与服务器功能差异如何区分?  Android自定义控件实现温度旋转按钮效果  如何自定义建站之星网站的导航菜单样式?  长沙做网站要多少钱,长沙国安网络怎么样?  盘锦网站制作公司,盘锦大洼有多少5G网站?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  jQuery 常见小例汇总  建站之星如何快速解决建站难题?  网页设计网站制作软件,microsoft office哪个可以创建网页?  建站之星如何配置系统实现高效建站?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  如何正确下载安装西数主机建站助手?  制作网站的公司有哪些,做一个公司网站要多少钱?  如何选择高效稳定的ISP建站解决方案?  家具网站制作软件,家具厂怎么跑业务?  定制建站如何定义?其核心优势是什么?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  ,怎么用自己头像做动态表情包?  建站主机系统SEO优化与智能配置核心关键词操作指南  西安大型网站制作公司,西安招聘网站最好的是哪个?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  如何通过智能用户系统一键生成高效建站方案?  如何通过WDCP绑定主域名及创建子域名站点?  建站之星如何防范黑客攻击与数据泄露?  如何选择高效可靠的多用户建站源码资源?  如何在Windows虚拟主机上快速搭建网站?  已有域名和空间,如何快速搭建网站?  如何通过IIS搭建网站并配置访问权限?  官网自助建站平台指南:在线制作、快速建站与模板选择全解析  如何配置FTP站点权限与安全设置?  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  如何快速辨别茅台真假?关键步骤解析 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。