0

0

C# SignalR文件传输 C#如何利用SignalR实现客户端与服务器的文件交换

月夜之吻

月夜之吻

发布时间:2026-02-20 11:28:03

|

887人浏览过

|

来源于php中文网

原创

signalr 不适用于大文件传输,必须分块上传并校验哈希。应使用 http 接口上传分片,signalr 仅用于进度广播;服务端需缓冲请求、校验每块及全量 sha256,避免内存溢出与数据损坏。

c# signalr文件传输 c#如何利用signalr实现客户端与服务器的文件交换

SignalR 本身不支持大文件传输,别直接传 byte[]

SignalR 的 Hub 方法默认序列化走 JSON,且有默认消息大小限制(通常 32 KB)。直接把整个文件读成 byte[] 传给 hub.InvokeAsync("UploadFile", fileBytes) 会触发 InvalidOperationException: The message size exceeds the configured maximum 或直接超时。这不是配置调大就能解决的——JSON 序列化大数组开销高、内存暴涨、易被浏览器或代理截断。

  • 必须分块(chunk)上传,每块控制在 64–256 KB,用 ArraySegment<byte></byte>Memory<byte></byte> 持有,避免重复拷贝
  • 客户端需维护上传进度 ID(如 GUID),服务端用 ConcurrentDictionary<string memorystream></string> 或临时文件暂存分块
  • 最后一步由客户端发“完成”指令,服务端合并并保存到磁盘或 Blob 存储

前端用 fetch + ReadableStream 更稳,别依赖 HubConnection.invoke

SignalR 的 JS 客户端对二进制流支持弱,invoke 只适合小数据。大文件应绕过 Hub,改用普通 HTTP 接口上传,再通过 SignalR 广播状态(如 “上传中”、“已保存”、“校验失败”)。

Flux AI
Flux AI

Flux AI,释放你的想象力,用文字生成图像

下载
  • 后端暴露一个 POST /api/upload/{uploadId},接收 multipart/form-data 或原始 application/octet-stream
  • 前端用 fetch 分片上传,配合 AbortController 支持暂停/重试
  • 上传过程中调用 connection.invoke("UpdateProgress", uploadId, progress) 同步进度给其他客户端
  • 避免在 Hub 方法里做 IO(如 File.WriteAllBytes),全部交给后台服务或托管服务处理

IFormFile 在 Controller 中接收分片,注意 Request.Body 流不可重复读

ASP.NET Core 默认将 Request.Body 缓存在内存或临时文件中,但若你手动调用 Request.Body.ReadAsync 一次后没重置位置(Seek),后续读取会返回空。尤其在用 IFormFile 时,它的 OpenReadStream() 返回的是新流,但底层 Request.Body 已被消耗。

  • 确保 Startup.csProgram.cs 中启用缓冲:app.UseRequestBuffering()(.NET 6+)
  • 不要混合使用 IFormFile 和直接读 Request.Body;选一种方式到底
  • 分片上传建议用裸流:await request.Body.CopyToAsync(tempFileStream),比 IFormFile 更可控
  • 记得检查 Content-Range 头来定位当前块偏移,别依赖表单字段顺序

服务端合并分块前必须校验 SHA256,别只靠文件名或 ID

多个客户端可能用相同 uploadId 并发上传,或网络导致某块重复提交。仅靠内存字典或文件名拼接无法保证完整性。必须在客户端计算每块哈希,服务端验证并最终对完整文件再算一次总哈希。

  • 客户端上传每块时附带 X-Chunk-Hash: sha256... 头,服务端用 SHA256.HashData(chunkBytes) 校验
  • 所有块接收完成后,从临时存储重新读取全量数据流,计算最终 SHA256,和客户端预提交的 X-File-Hash 对比
  • 校验失败则删临时文件,返回 400,并要求客户端重传——别静默覆盖或写坏文件
  • 临时文件路径别硬编码,用 Path.GetTempFileName() 或注入 IWebHostEnvironment.WebRootPath 下的子目录
SignalR 是实时通信的胶水,不是文件传输协议。真正卡点永远在流控制、内存管理、并发安全和端到端校验——这些细节没压住,光连上 Hub 没用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

442

2023.08.07

json是什么
json是什么

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

544

2023.08.23

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

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

322

2023.10.13

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

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

81

2025.09.10

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1536

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

423

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2261

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

37

2026.01.19

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

776

2026.02.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.8万人学习

C 教程
C 教程

共75课时 | 4.8万人学习

C++教程
C++教程

共115课时 | 18.6万人学习

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

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