这是Blazor上传文件的最佳方式吗?

Blazor不得不说真是好东西,极大的提升了开发效率,很多的页面交互功能基本上只需要写很少的代码就能实现了,而且还是无js实现,你也绝对没有想到过,Blazor实现文件上传是有多么简单!

先说结论:Blazor实现带进度显示的文件上传真的很简单!效果看图:

07fa88ba0d50e721f612b57cd88ddaea.gif

实现这么一个小功能,仅仅只花了不到50行的代码就实现了,接下来就给大家分享下案例实现吧。

首先引入Tewr.Blazor.FileReader包,这个包能够提供文件上传的流式读取,这样便可以实现在服务端对上传文件进行一边上传一遍写文件的操作。

配置依赖注入(站长注:这是Blazor Server模式,wasm方式请查看文末仓库文档说明):

services.AddFileReaderService();

接下来我们先进行页面布局,很简单,再声明两个变量用于显示进度和显示图片:

<input type="file"/><button>上传文件</button>
<div>@if (!string.IsNullOrEmpty(_src)){<img src="@_src" width="600px" />}else{<p>@progress</p>}
</div>

然后在组件中注入IFileReaderService服务

@using Tewr.Blazor.FileReader
@inject IFileReaderService fileReaderService;

为了让文件框能够和C#代码进行交互,所以需要将它通过ElementReference引用起来:

<input @ref=inputTypeFileElement type="file" /><button>上传文件</button>
<div>@if (!string.IsNullOrEmpty(_src)){<img src="@_src" width="600px" />}else{<p>@progress</p>}
</div>
@code {private ElementReference inputTypeFileElement;private string _src;private string progress;
}

给按钮绑定事件,按钮触发后通过fileReaderService进行文件流的读取,接下来便是常规的二进制数据copy操作,可以拿到文件的传输进度,计算之后便能显示到页面中

<button @onclick=ReadFile>上传文件</button>
public async Task ReadFile()
{_src = "";foreach (var file in await fileReaderService.CreateReference(inputTypeFileElement).EnumerateFilesAsync()){await using var fileStream = await file.OpenReadAsync();var buffer = new byte[2048];var finalBuffer = new byte[fileStream.Length];int count;int totalCount = 0;while ((count = await fileStream.ReadAsync(buffer, 0, buffer.Length)) != 0){Buffer.BlockCopy(buffer, 0, finalBuffer, totalCount, count);totalCount += count;progress = "文件上传中 " + (int)(totalCount * 100.0 / fileStream.Length) + "%";StateHasChanged();}_src = $"data:image/jpg;base64,{Convert.ToBase64String(finalBuffer)}";progress = "";StateHasChanged();}
}

完整代码如下:

@page "/counter"
@using Tewr.Blazor.FileReader
@inject IFileReaderService fileReaderService;<input @ref=inputTypeFileElement type="file" />
<button @onclick=ReadFile>上传文件</button>
<div>@if (!string.IsNullOrEmpty(_src)){<img src="@_src" width="600px" />}else{<p>@progress</p>}
</div>@code {private ElementReference inputTypeFileElement;private string _src;private string progress;public async Task ReadFile(){_src = "";foreach (var file in await fileReaderService.CreateReference(inputTypeFileElement).EnumerateFilesAsync()){await using var fileStream = await file.OpenReadAsync();var buffer = new byte[2048];var finalBuffer = new byte[fileStream.Length];int count;int totalCount = 0;while ((count = await fileStream.ReadAsync(buffer, 0, buffer.Length)) != 0){Buffer.BlockCopy(buffer, 0, finalBuffer, totalCount, count);totalCount += count;progress = "文件上传中 " + (int)(totalCount * 100.0 / fileStream.Length) + "%";StateHasChanged();}_src = $"data:image/jpg;base64,{Convert.ToBase64String(finalBuffer)}";progress = "";StateHasChanged();}}
}

站长插播:

文章首图演示的是一张不到1MB的图片,因为Tewr.Blazor.FileReader这个包提供文件上传的流式读取,上传大文件也是可以的,下面这是上传一个34.2MB的ZIP压缩包,Blazor服务端模式:

9a495b80d89b6f8d6fe00b6199964b35.gif

demo做的一般,可能gif看不出啥,只是为了证明这个包确实不错,要实现大文件上传,可把上面单包读取大小改大一点,比如:512KB:

var buffer = new byte[1024*512];

如果看下方微软Blazor文件上传文档,把单包大小改成大于20KB,页面可能会卡一下,然后页面自动刷新就把上传操作给重置了,而使用这个包确没这个问题,这个包很nice。

OK,本文完。

参考

  • Blazor实现文件上传带进度显示案例分享[1]

  • https://github.com/Tewr/BlazorFileReader[2]

  • https://docs.microsoft.com/zh-cn/aspnet/core/blazor/file-uploads?view=aspnetcore-6.0&pivots=server[3]

参考资料

[1]

Blazor实现文件上传带进度显示案例分享: https://masuit.com/1676

[2]

https://github.com/Tewr/BlazorFileReader: https://github.com/Tewr/BlazorFileReader

[3]

https://docs.microsoft.com/zh-cn/aspnet/core/blazor/file-uploads?view=aspnetcore-6.0&pivots=server: https://docs.microsoft.com/zh-cn/aspnet/core/blazor/file-uploads?view=aspnetcore-6.0&pivots=server

e74695ae7543ddf808dc18080c9d6963.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/290358.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS SQLite函数总结

1.打开数据库 int sqlite3_open( const char *filename, // 数据库的文件路径 sqlite3 **ppDb // 数据库实例 ); 2.执行任何SQL语句 int sqlite3_exec( sqlite3*, // 一个打开的数据库实例 const char *sql, …

ubuntu 下安装五笔输入法

2019独角兽企业重金招聘Python工程师标准>>> 从两年开始用五笔的吧&#xff0c;自从我学会用五笔之后&#xff0c;基本上就没有用过拼音了&#xff0c;我记忆中使用拼音也就那么几次&#xff0c;好像都是在远程协助别人的时候&#xff0c;用他们电脑上的拼音。然后我…

openstack horizon国际化分析

2019独角兽企业重金招聘Python工程师标准>>> 参考 官网国际化介绍&#xff1a;https://docs.djangoproject.com/en/1.7/topics/i18n/translation/#module-django.conf.urls.i18n Django模板&#xff08;网页多语种支持/国际化&#xff09;&#xff1a; http://blog.…

6. 堪比JMeter的.Net压测工具 - Crank 实战篇 - 收集诊断跟踪信息与如何分析瓶颈

1. 前言上面我们已经做到了接口以及场景压测&#xff0c;通过控制台输出结果&#xff0c;我们只需要将结果收集整理下来&#xff0c;最后汇总到excel上&#xff0c;此次压测报告就可以完成了&#xff0c;但收集报告也挺麻烦的&#xff0c;交给谁呢……找了一圈、没找到愿意接手…

C和指针之字符串之strlen、strcpy、 strcat、strcmp使用总结

1、常见字符串相关操作 我们知道有strlen、 strcpy、strcat、strcmp、这样一一系列函数 2、实现Demo #include <stdio.h> #include <string.h>//求字符串长度并且打印 void get_len(char *p) {int len = strlen(p);printf("%s len is %d\n", p, len); …

被AI人机疯狂单杀?王者荣耀AI“绝悟”亲测体验

文章目录&#xff08;一&#xff09; 如何评测“绝悟”的智能程度&#xff1f;&#xff08;二&#xff09;“绝悟”个体操作能力分析2.1 草丛埋伏2.2 越塔强杀2.3 技能避伤2.4 技能combo&#xff08;三&#xff09;“绝悟”团队意识能力分析3.1 团队支援3.2 团队控龙3.3 反野意…

background意识(两)

今天看到了有关学习的价值的文章background于background-position该博客&#xff0c;现在与大家分享&#xff1a;语法&#xff1a; background-position : length || length background-position : position || position 取值&#xff1a; length&#xff1a;百分数 |由浮点数字…

js 月份加6个月_美国切削工具6月份订单较上月增加10.1

根据美国切削工具协会(USCTI)和AMT美国制造技术协会的数据&#xff0c;2020年6月&#xff0c;美国切削工具的总消费额为1.506亿美元。根据参与切削工具市场报告合作的公司报告&#xff0c;这一总额比5月份的1.368亿美元增长了10.1%&#xff0c;与2019年6月报告的1.997亿美元相比…

Yet another nio framework for java

项目名称&#xff1a;Yanf4j(Yet another nio framework for java)项目地址&#xff1a;http://code.google.com/p/yanf4j/,当前版本0.30-beta1协议&#xff1a;Apache License, Version 2.0 简单描述&#xff1a;有这么多nio框架了&#xff0c;为什么要another&#xff1f;重复…

selenium 使用js执行脚本儿链接整理

2019独角兽企业重金招聘Python工程师标准>>> 使用Webdriver执行js小结&#xff1a;http://lijingshou.iteye.com/blog/2018929 SeleniumWebdriver学习(三)执行JS脚本&#xff1a;http://www.tuicool.com/articles/buIbeiN selenium webdriver 执行javascript代码&am…

C和指针之字符串之strncpy、strncat、strncmp

1、strncpy、strncat、strncmp 1)、函数原型char *strncpy(char *dest,char *src,size_t n); 复制字符串src中的内容(字符,数字、汉字....)到字符串dest中,复制多少由size_t n的值决定。如果src的前n个字符不含NULL字符,则结果不会以NULL字符结束。如果n<src的长度,只…

接口返回json对象出现套娃递归问题 | System.Text.Json 版本

前言看到一篇文章《Asp-Net-Core开发笔记&#xff1a;接口返回json对象出现套娃递归问题》原文是使用 NewtonsoftJson 解决的返回json对象出现套娃递归问题&#xff1a;services.AddControllersWithViews().AddNewtonsoftJson(options > {options.SerializerSettings.Refere…

高效性跨平台分布式软件开发技术——gRPC

文章目录1. gRPC&#xff08;google Remote Procedure Call&#xff09; 技术 —— 高效性地跨平台、跨语言开发2. 基于 python 实现 gRPC 框架2.1 一个 gPRC 项目必须包含的几大部分2.2 helloworld.proto 文件——定义全局可调用函数及其参数数据结构2.3 server.py 文件——实…

在VS中设置比较和谐的字体和颜色的方法

作者&#xff1a;朱金灿来源&#xff1a;http://blog.csdn.net/clever101先在studiostyl.es网站选择你喜欢的字体方案&#xff0c;我个人比较喜欢这款&#xff1a;Humane Studio&#xff0c;注意在网页上选择你使用VS版本&#xff0c;然后单击Downlaod this scheme就可以了&…

C和指针之字符串strchr、strpbrk、strstr

1、strchr、strpbrk、strstr 1) char *strchr(const char *s, int c); 在s中找字符c 第一次出现的地方,返回这个指向该位置的指针,没找到返回NULL 2) char *strrchr(const char *s, int c); 在s中最右边找字符c 第一次出现的地方,返回这个指向该位置的指针,没…

一个脚本实现全量增量备份,并推送到远端备份中心服务器

2019独角兽企业重金招聘Python工程师标准>>> 摘要 由于工作需要&#xff0c;刚好需要这样一个功能的脚本&#xff0c;主要解决&#xff1a; 1. 不想在crontab中调度两条备份任务&#xff0c;一个做全量一个做增量 2. 如果每小时做增量&#xff0c;凌晨4点做全量&…

.NET 7 预览版 2 已发布,NativeAOT 正式可用

.NET 7 Preview 2 已发布&#xff0c;第二个预览版包括对 RegEx 源生成器的增强、将 NativeAOT 从实验状态转移到运行时的进展&#xff0c;以及对“dotnet new”CLI SDK 的一系列重大改进。在此下载适用于 Windows、macOS 和 Linux 的 .NET 7 Preview 2 。引入新的正则表达式源…

地壳中元素含量排名记忆口诀_Nature:利用熔融包裹体的元素和同位素示踪俯冲带流体来源...

Nature&#xff1a;利用熔融包裹体的元素和同位素示踪俯冲带流体来源在汇聚板块边缘&#xff0c;大洋岩石圈通过俯冲作用携带挥发分(尤其是水)进入地幔。这些俯冲下去的水/流体控制着岩浆产物、地震活动、陆壳形成和资源成矿。但是&#xff0c;识别不同流体的来源(沉积物&#…

Windows 10开发基础——文件、文件夹和库(一)

Windows 10开发基础——文件、文件夹和库&#xff08;一&#xff09; 原文:Windows 10开发基础——文件、文件夹和库&#xff08;一&#xff09;主要内容&#xff1a; 1.枚举查询文件和文件夹 2.文本文件读写的三种方法——创建写入和读取文件 3.获得文件的属性 枚举查询文件和…

Sigmoid函数与逻辑回归

文章目录(1). Sigmoid函数的由来——伯努利分布的衍生物1.1 为什么会有 sigmoid 函数的出现&#xff1f;1.2 sigmoid 函数推导过程1.3 sigmoid 函数求导(2). 逻辑回归&#xff08;Logistic Regression&#xff09;2.1 逻辑回归算法的最终本质——求决策边界2.2 逻辑回归算法中的…