新闻中心

.NET中的gRPC-Web是什么?如何让浏览器应用调用gRPC服务?

2025-11-19
浏览次数:
返回列表
gRPC-Web是为浏览器设计的gRPC变体,通过HTTP/1.1封装调用,需在.NET中启用gRPC-Web中间件、生成前端stub并配置CORS,支持一元和客户端流式调用。

.net中的grpc-web是什么?如何让浏览器应用调用grpc服务?

gRPC-Web 是 gRPC 的一种变体,专为浏览器环境设计。标准的 gRPC 使用 HTTP/2 的双向流和多路复用特性,但大多数浏览器不支持直接使用 HTTP/2 发起 gRPC 调用,因此无法在前端 J*aScript 中直接调用原生 gRPC 服务。gRPC-Web 就是为了解决这个问题而诞生的。

什么是 gRPC-Web?

gRPC-Web 是一个允许浏览器应用通过 J*aScript 或 TypeScript 调用 gRPC 服务的协议。它在客户端使用普通的 HTTP 请求(通常是 HTTP/1.1),将 gRPC 调用封装成兼容 Web 的格式。由于浏览器安全策略和网络栈的限制,gRPC-Web 并不支持所有 gRPC 功能,比如服务器流式响应在某些模式下受限,但支持一元调用(unary call)和客户端流。

关键点:

  • gRPC-Web 不是直接运行在 HTTP/2 上,而是通过代理转换请求
  • 需要后端部署一个 gRPC-Web 兼容的代理或启用支持中间件
  • 前端使用生成的客户端 stub 调用服务,就像调用普通 API 一样

如何让浏览器应用调用 gRPC 服务?

要在 .NET 环境中实现浏览器调用 gRPC 服务,需完成以下步骤:

1. 在服务端启用 gRPC-Web 支持

如果你使用的是 ASP.NET Core gRPC 服务,可以通过添加中间件来支持 gRPC-Web。从 .NET 5 开始,官方提供了对 gRPC-Web 的支持。

Program.cs 中配置:

var builder = WebApplication.CreateBuilder(args);
builder.Services.AddGrpc();

var app = builder.Build();

app.UseRouting();

// 启用 gRPC-Web 中间件
app.UseGrpcWeb(new GrpcWebOptions { DefaultEnabled = true });

// 映射你的 gRPC 服务
app.MapGrpcService<YourGrpcService>();

app.Run();

这样,gRPC 服务就可以接受来自浏览器的 gRPC-Web 请求了。

2. 前端使用 gRPC-Web 客户端库

在浏览器端,不能使用原生 gRPC 客户端,必须使用 gRPC-Web 提供的 J*aScript 客户端。推荐使用 grpc-web npm 包。

安装:

Eclipse中创建Web Maven Project并部署到Tomcat中 中文WORD版 Eclipse中创建Web M*en Project并部署到Tomcat中 中文WORD版

大家都知道,在进行J2EE项目的开发过程中,在调试阶段如果只是修改了页面是不需要重启应用服务器的,比如不需要重启Tomcat。只需要在浏览器中 进行页面刷新即可。其实之所以不用重启Tomcat等应用服务器,其根本原因是因为我们可以在应用服务器的配置文件中设置虚拟目录,这样就可以知道web 项目所在的目录,于是就可以省去打包、然后再重新发布到服务器的步骤。感兴趣的朋友可以过来看看

Eclipse中创建Web Maven Project并部署到Tomcat中 中文WORD版 0 查看详情 Eclipse中创建Web Maven Project并部署到Tomcat中 中文WORD版
npm install grpc-web google-protobuf

然后使用 protoc 和插件生成前端可用的客户端代码:

protoc --js_out=import_style=commonjs,binary:. \
       --grpc-web_out=import_style=commonjs,mode=grpcwebtext:. \
       your_service.proto

这会生成 YourServiceClient.js 和消息类文件。

3. 在前端代码中调用服务

示例(TypeScript 或 J*aScript):

import { YourServiceClient } from './generated/YourServiceClient';
import { YourRequest } from './generated/YourRequest';
import { YourResponse } from './generated/YourResponse';

const client = new YourServiceClient('https://localhost:7001');

const request = new YourRequest();
request.setName('Alice');

client.yourMethod(request, {}, (err, response: YourResponse) => {
  if (err) {
    console.error(err);
    return;
  }
  console.log(response.getMessage());
});

注意:URL 指向的是启用 gRPC-Web 的 ASP.NET Core 服务地址。

4. 处理跨域问题(CORS)

如果前端和 gRPC 服务不在同一域名下,需要配置 CORS:

builder.Services.AddCors(options =>
{
    options.AddPolicy("AllowAll", policy =>
    {
        policy.AllowAnyOrigin()
              .AllowAnyHeader()
              .AllowAnyMethod();
    });
});

// 在 UseRouting 之后启用 CORS
app.UseCors("AllowAll");

总结

gRPC-Web 让浏览器可以直接调用后端 gRPC 服务,提升了前后端通信效率和类型安全性。在 .NET 中,只需启用 gRPC-Web 中间件,配合前端生成的客户端代码,即可实现高性能、强类型的 API 调用。虽然不支持所有流式场景,但对于大多数 Web 应用的一元调用已完全够用。

基本上就这些,不复杂但容易忽略中间件顺序和 CORS 配置。

以上就是.NET中的gRPC-Web是什么?如何让浏览器应用调用gRPC服务?的详细内容,更多请关注其它相关文章!


# 重启  # 方山比较好的网站推广联系人  # 网站上写着VI推广卖的是假货吗  # 婚恋网站推广文案  # 广告投放平台网站推广  # 松原网站整合营销推广  # 亚马逊代购网站建设  # 高流量网站优化  # seo描述怎么写范本  # 萍乡技术营销推广代理商  # 武夷山网络seo介绍  # 流式  # 要在  # 只需  # 不需要  # 就可以  # javascript  # 的是  # 如何处理  # 客户端  # goog  # 跨域  #   # 后端  # app  # 浏览器  # npm  # typescript  # go  # 前端  # js  # java 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: Centos/Linux 系统下安装 composer 的完整步骤  内存检查:在VS Code中调试C++时的内存视图  Win11如何使用Windows Sandbox Win11沙盒功能开启与使用教程【详解】  Tabulator表格日期时间排序问题及自定义解决方案  163邮箱官方主页登录 直达网易邮箱登录核心页面  Django表单验证失败时保留用户输入数据的最佳实践  钉钉视频会议声音异常如何处理 钉钉会议音频修复技巧  Go语言中Map值调用指针接收器方法的限制与应对  电脑安装程序提示“错误1722”怎么办_Windows Installer服务问题解决【教程】  妖精动漫免费平台 妖精动漫官网资源观看网址  漫蛙漫画网页端入口 漫蛙2官方正版漫画站点  将HTML动态表格多行数据保存到Google Sheet的教程  TikTok国际版官网直达_TikTok国际版官网直达进入在线观看  mc.js免安装版 mc.js一键畅玩入口  如何有效阻止外部脚本意外修改内联样式的高度属性  抖音从哪里进入网页版_抖音官方入口链接  如何创建独立于主系统的J*a运行环境_隔离式环境搭建策略  《北京人工智能产业白皮书(2025)》发布:全年核心产值预计突破 4500 亿元  mc.js游戏直达 mc.js网页免下载版本秒进地址  腾讯QQ邮箱官方网站_QQ邮箱网页版在线登录  J*aScript map 迭代中检测空数组元素的有效方法  处理动态列数据:J*a ArrayList的正确初始化与字符累加教程  J*aScript实现动态背景色下的文本与按钮颜色自适应调整  京东京造J1和网易云音乐氧气真无线有什么不同_国产电商蓝牙耳机音质对比  优化Django表单:提交验证失败后保留用户输入  windows10怎么查看硬盘序列号_windows10硬盘id查询命令  Safari自带网页翻译功能怎么用 无需插件轻松看懂外文网站【方法】  利用5118提升短视频内容效果_5118短视频关键词优化方法  CSS布局:解决全屏元素100%尺寸与外边距导致的页面溢出问题  Angular响应式表单:实现提交后表单及按钮的禁用与只读化  如何在CSS中使用visited与link控制链接颜色_visited link伪类配合  小米14应用无法联网原因分析_小米14网络权限修复  mysql如何设置表访问权限_mysql表访问权限配置  Basecamp怎样用留言钉固定重点_Basecamp用留言钉固定重点【重点标记】  Win11蓝牙耳机断连怎么解决 Win11蓝牙设置重新配对与驱动更新【技巧】  微信网页版官方入口直达 微信网页版网页版登录使用方法  J*aScript实现单选按钮与关联输入框的联动禁用教程  基于动态规划的房屋花卉种植最小成本算法详解  Django表单提交验证失败后保持字段值不刷新  DLsite中文平台入口 DLsite官网内容在线查看  Win11网速慢怎么解决 Win11网络设置优化解除限速  快手网页版在线登录 快手网页版官网入口快速访问  css卡片内容溢出如何处理_使用overflow隐藏或scroll显示内容  抓大鹅无需下载版 抓大鹅秒玩版入口  J*aScript教程:根据元素文本内容动态设置背景色  汽车之家官方网站官网入口_汽车之家网页版直接进入  C++如何操作注册表_Windows平台下C++读写注册表的API函数详解  抖音小游戏合成大西瓜免费秒玩入口链接 抖音小游戏热门合集秒玩网站  俄罗斯浏览器官网直达链接 俄罗斯浏览器最新在线入口导航  J*a TimerTask中HashMap意外清空的深层原因与解决方案 

搜索