Blazor 创建和注入 API Service 的方法

Blazor中创建和注入API Service的核心是定义接口与实现类封装HTTP调用,通过DI注册(WebAssembly用Singleton、Server用Scoped),并在OnInitializedAsync中异步调用;需注意HttpClient配置、CORS、生命周期匹配及错误处理。

blazor 创建和注入 api service 的方法

在 Blazor 中创建和注入 API Service 的核心是:定义服务类封装 HTTP 调用,通过依赖注入(DI)注册到服务容器,并在组件中按需使用。关键在于区分服务生命周期、正确处理异步、适配 Blazor Server 与 WebAssembly 的差异。

定义 API Service 类

新建一个 C# 类(如 WeatherForecastService.cs),继承 IWeatherForecastService 接口(推荐,利于测试和解耦)。内部使用 IHttpClientFactory 或直接注入 HttpClient(WebAssembly 下需注意配置)。

示例:

public interface IWeatherForecastService
{
Task GetForecastAsync(DateTime startDate);
}

public class WeatherForecastService : IWeatherForecastService
{
private readonly HttpClient _httpClient;

public WeatherForecastService(HttpClient httpClient)
{
_httpClient = httpClient;
_httpClient.BaseAddress = new Uri("https://localhost:5001/"); // WebAssembly 需确保跨域或代理
}

public async Task GetForecastAsync(DateTime startDate)
{
return await _httpClient.GetFromJsonAsync($"WeatherForecast?startDate={startDate:O}");
}
}

在 Program.cs 中注册服务

Blazor 从 .NET 6 起统一使用 Program.cs 配置 DI 容器。根据部署模型选择注册方式:

Blazor WebAssembly(托管或独立):注册为 Singleton,并配置 HttpClient 的基础地址和默认请求头Blazor Server:通常注册为 Scoped(配合 SignalR 生命周期),也可用 Singleton

示例(WebAssembly):

builder.Services.AddHttpClient(
client => client.BaseAddress = new Uri(builder.HostEnvironment.BaseAddress));
// 或手动注册(更灵活)
builder.Services.AddSingleton();
builder.Services.AddScoped(sp => new HttpClient
{
BaseAddress = new Uri(builder.HostEnvironment.BaseAddress)
});

在组件中注入并调用

使用 @inject 指令或构造函数注入。注意 Blazor 组件生命周期中,异步初始化需放在 OnInitializedAsync 中,避免在构造函数中执行异步操作。

示例(.razor 文件):

@page "/forecast"
@using MyApp.Services
@inject IWeatherForecastService ForecastService

Weather Forecast



@if (forecasts == null)
{

Loading...


}
else
{



@foreach (var forecast in forecasts)
{

}

DateTemp. (C)Summary
@forecast.Date.ToShortDateString()@forecast.TemperatureC@forecast.Summary

}

@code {
private WeatherForecast[]? forecasts;

protected override async Task OnInitializedAsync()
{
forecasts = await ForecastService.GetForecastAsync(DateTime.Now);
}
}

处理常见问题

实际开发中容易遇到以下情况:

CORS 报错(WebAssembly)后端需启用跨域,或使用 dev-server 代理proxy.conf.js 或 .NET 6+ 的 appsettings.Development.json 代理配置)HttpClient 实例复用问题:不要在服务中 new HttpClient;优先用 IHttpClientFactory 或由 DI 提供的实例认证与 Token 注入:可扩展 DelegatingHandler(如 AuthorizationMessageHandler)自动附加 JWT错误统一处理:在 Service 方法内捕获 HttpRequestException,转换为业务异常或返回 Result 封装类型

基本上就这些。不复杂但容易忽略细节,比如生命周期匹配、HttpClient 配置位置、以及 WebAssembly 下的 BaseAddress 来源。保持接口抽象、合理注册、异步生命周期对齐,API 调用就能稳定工作。

以上就是Blazor 创建和注入 API Service 的方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1442991.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 19:36:09
下一篇 2025年12月17日 19:36:30

相关推荐

  • C# yield关键字的作用 – 实现迭代器与状态机的简便方法

    yield关键字用于声明迭代器方法,使方法能逐个提供序列元素并自动管理状态;返回类型须为IEnumerable等,编译器自动生成状态机,支持延迟计算与内存优化。 yield 关键字在 C# 中不是用来“返回值”或“跳出方法”的,而是专门用于声明迭代器方法(iterator method)——它让方法…

    2025年12月17日
    000
  • Blazor Autocomplete/Typeahead 组件制作教程

    Blazor中可基于InputText、键盘事件、异步搜索与下拉渲染实现轻量Autocomplete组件;需包含防抖逻辑、键盘导航(方向键/Enter/ESC)、样式优化及空结果提示。 Blazor 中没有内置的 Autocomplete(也称 Typeahead)组件,但用 InputText +…

    2025年12月17日
    000
  • C#怎么遍历枚举 C# Enum.GetValues遍历方法

    在C#中遍历枚举最常用方式是Enum.GetValues,返回Array类型,需显式转换为具体枚举类型或使用C# 7.3+泛型重载;配合GetNames可获取名称与值;Flags枚举需手动位运算生成组合值。 在 C# 中遍历枚举最常用、最直接的方式就是用 Enum.GetValues,它返回一个包含…

    2025年12月17日
    000
  • Blazor 怎么自定义表单验证消息

    Blazor自定义表单验证消息主要有三种方式:一是用DataAnnotations+自定义ValidationAttribute实现字段级规则;二是用EditContext.ValidationMessageStore动态添加运行时业务错误;三是手动监听EditContext事件实现复杂联动校验。 …

    2025年12月17日
    000
  • Blazor 怎么实现拖放功能

    Blazor拖放依赖HTML5 drag & drop API,需设draggable=”true”、用@ondragstart/@ondragover/@ondrop绑定事件,注意阻止默认行为、数据传递及跨平台限制。 Blazor 实现拖放功能主要靠 HTML5 原…

    2025年12月17日
    000
  • Blazor WASM AOT 提升运行时性能的方法

    AOT编译可提升Blazor WebAssembly性能,但需显式启用、精简反射依赖、优化渲染逻辑并结合Web API协同调优。 Blazor WebAssembly(WASM)启用 AOT(Ahead-of-Time)编译后,能显著减少 JIT 开销、缩短启动时间、提升执行效率。但 AOT 本身不…

    2025年12月17日
    000
  • C# For和Foreach循环的性能差异 – 遍历集合的最佳选择

    for在数组和List等支持随机访问的集合中通常更快,因无枚举器开销;foreach更安全可读,适合多数场景且不易出错。 在C#中,for 和 foreach 都能遍历集合,但性能表现并不总是一样。关键看集合类型、是否需要索引、以及是否在循环中修改集合 —— 这些因素直接影响哪种写法更高效、更安全。…

    2025年12月17日
    000
  • C# init访问器是什么 – C# 9.0中的只读属性初始化

    init访问器是C# 9.0引入的仅限对象初始化阶段使用的属性设置器,支持在对象初始化器中为只读属性赋值,之后不可修改,增强不可变性,适用于DTO、record等场景。 init访问器是 C# 9.0 引入的一种特殊属性设置器,用于在对象初始化期间为只读属性赋值,之后该属性便不能再被修改。它解决了以…

    2025年12月17日
    000
  • ASP.NET Core怎么进行身份验证和授权 JWT认证实现教程

    ASP.NET Core 中 JWT 身份验证核心是配置 Authentication 与 Authorization 中间件,流程为登录发 Token → 请求带 Token → 中间件自动校验 → 控制器用 [Authorize] 限定访问;需正确注册 JWT Bearer 服务、生成 Toke…

    2025年12月17日
    000
  • Blazor 怎么给 HTTP 请求添加认证头

    Blazor中HTTP认证头配置核心是按场景选择方式:WASM推荐用DelegatingHandler动态注入Bearer Token,Server端通常无需前端加头。 在 Blazor 中给 HTTP 请求添加认证头,核心是配置 HttpClient 实例,使其自动携带如 Authorizatio…

    2025年12月17日
    000
  • Blazor 怎么发起 HTTP 请求

    Blazor发起HTTP请求应使用注入的HttpClient而非new实例,以避免连接泄漏;Server端默认注册IHttpClientFactory,WASM端受CORS限制且需配置凭据支持;推荐封装API客户端服务并统一处理错误与加载状态。 Blazor 发起 HTTP 请求主要靠 IHttpC…

    2025年12月17日
    000
  • Blazor 怎么从配置中读取连接字符串

    Blazor Server可通过IConfiguration或IOptions读取服务端appsettings.json中的连接字符串,而Blazor WebAssembly因运行在浏览器中,绝不可存放或读取连接字符串,必须通过后端API访问数据库,确保敏感信息仅存在于服务端安全存储中。 Blazo…

    2025年12月17日
    000
  • C#如何实现PDF文件生成 QuestPDF库使用教程

    QuestPDF 是 .NET 平台最轻量现代的 PDF 生成库,基于 Fluent API 用 C# 直接描述文档结构,需注册中文字体(如 Noto Sans CJK)以支持中文,安装 via NuGet,.NET 6+ 原生兼容。 用 C# 生成 PDF,QuestPDF 是目前最轻量、现代且易…

    2025年12月17日
    000
  • C#如何使用dynamic关键字 C#动态类型dynamic用法

    dynamic是C#中将类型检查推迟到运行时的特殊类型,适用于COM交互、反射调用、动态JSON处理及DSL构建等场景,但会丢失编译检查与IDE支持。 dynamic 是 C# 中用于绕过编译时类型检查的特殊类型,它把类型解析推迟到运行时。用它不是为了“替代”静态类型,而是为了解决某些特定场景下类型…

    2025年12月17日
    000
  • C# 中的Monitor.Wait和Pulse – 底层的线程同步原语

    Monitor.Wait 和 Monitor.Pulse 是 C# 中基于对象的线程同步原语,用于实现等待-通知机制:Wait 释放锁并使线程进入等待队列,Pulse 向队列中一个线程发送唤醒信号但不释放锁,二者需配合循环条件检查使用。 在 C# 中,Monitor.Wait 和 Monitor.P…

    2025年12月17日
    000
  • WPF怎么实现数据绑定 WPF MVVM数据绑定方法

    WPF数据绑定依赖DependencyProperty和INotifyPropertyChanged,ViewModel需实现该接口并触发PropertyChanged事件,View通过DataContext关联ViewModel,Binding路径须为public属性且区分大小写,集合应使用Obs…

    2025年12月17日
    000
  • Blazor 怎么集成 SignalR

    Blazor集成SignalR分三步:服务端定义Hub并注册、客户端安装包并建立连接、收发消息;推荐WASM模式以节省服务器资源;需注意路径大小写、CORS配置及开发期错误设置。 Blazor 集成 SignalR 主要分服务端 Hub 定义、客户端连接、消息收发三步,WebAssembly(WAS…

    2025年12月17日
    000
  • Blazor ElementReference.FocusAsync() 使用方法

    ElementReference.FocusAsync() 用于让 HTML 元素获得焦点,需 await 调用且仅在组件已渲染、元素存在于 DOM 时有效;应通过 @ref 绑定 ElementReference,避免在 OnInitialized 中调用,推荐在 OnAfterRender(配合…

    2025年12月17日
    000
  • C# LINQ中的SelectMany有什么用 – 将嵌套集合扁平化

    SelectMany用于将集合的集合扁平化为单层集合,支持投影、过滤与关联操作。例如,从学生列表中提取所有课程:var allCourses = students.SelectMany(s => s.Courses); 可保留上下文信息,如学生姓名与序号:.SelectMany((s, i) …

    2025年12月17日
    000
  • C#怎么使用IHttpClientFactory C# HttpClientFactory最佳实践

    IHttpClientFactory是.NET Core 2.1+推荐的HttpClient管理方式,解决new HttpClient导致的连接泄漏、DNS缓存不更新和SSL复用问题;它通过复用HttpMessageHandler提升性能与可靠性,并支持命名客户端、类型化客户端及Polly策略集成。…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信