基于.NET 9实现实时进度条功能:前后端完整示例教程

要在基于.NET 9的应用中实现进度条功能,我们可以通过HttpContext.Response来发送实时的进度更新到前端。以下是一个简单的示例,展示了如何在ASP.NET Core应用中实现这一功能。

但是,我在.net framework4.7.2框架下,实际不了HttpContext.Response.WriteAsync,发贴求解决办法

后端代码(C#)

首先,我们需要创建一个ASP.NET Core控制器动作,该动作将模拟一个长时间运行的任务,并在任务执行过程中发送进度更新。

cs 复制代码
using Microsoft.AspNetCore.Mvc;
using System;
using System.Threading;
using System.Threading.Tasks;
[ApiController]
[Route("[controller]")]
public class ProgressController : ControllerBase
{
    [HttpGet("start")]
    public async Task StartLongRunningTask()
    {
        // 设置响应头,指示这是一个长时间运行的请求
        HttpContext.Response.Headers.Add("Connection", "keep-alive");
        HttpContext.Response.Headers.Add("Content-Type", "text/event-stream");
        HttpContext.Response.Headers.Add("Cache-Control", "no-cache");
        // 模拟长时间运行的任务
        for (int i = 0; i <= 100; i++)
        {
            // 发送进度更新
            await SendProgress(i);
            // 模拟工作负载
            await Task.Delay(100);
        }
        // 任务完成,关闭连接
        await HttpContext.Response.Body.FlushAsync();
        HttpContext.Response.Body.Close();
    }
    private async Task SendProgress(int percentage)
    {
        var data = $"data: {percentage}\n\n";
        var bytes = System.Text.Encoding.UTF8.GetBytes(data);
        await HttpContext.Response.Body.WriteAsync(bytes, 0, bytes.Length);
        await HttpContext.Response.Body.FlushAsync();
    }
}

二、前端代码(HTML + JavaScript)

接下来,我们需要创建一个简单的HTML页面,用于显示进度条,并使用JavaScript来接收后端发送的进度更新。

cs 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Progress Bar Example</title>
    <style>
        #progressBar {
            width: 0%;
            height: 30px;
            background-color: green;
            text-align: center;
            line-height: 30px;
            color: white;
        }
    </style>
</head>
<body>
    <div id="progressBar">0%</div>
    <button onclick="startProgress()">Start Task</button>
    <script>
        function startProgress() {
            const eventSource = new EventSource('/Progress/start');
            eventSource.onmessage = function(event) {
                const progressBar = document.getElementById('progressBar');
                progressBar.style.width = event.data + '%';
                progressBar.textContent = event.data + '%';
            };
            eventSource.onerror = function() {
                eventSource.close();
                console.error('EventSource failed.');
            };
        }
    </script>
</body>
</html>
相关推荐
遇到困难睡大觉哈哈1 小时前
Harmony os 网络防火墙实战:用 @ohos.net.netFirewall 给应用加一道“网闸”
网络·.net·harmonyos·鸿蒙
搬砖的工人2 小时前
.NET 9.0 与 Swagger 的集成实践:一步步构建Api文档
.net
唐青枫2 小时前
C#.NET Record Struct 完全解析:语法、语义与最佳实践
c#·.net
时光追逐者12 小时前
分享5款.NET开源免费的Redis客户端组件库
数据库·redis·开源·c#·.net·.net core
张人玉1 天前
Prism Template Pack 完整使用示例(VS2022 + .NET 8 + DryIoc)
.net·wpf·prism
j***63081 天前
四大.NET ORM框架深度对比:EF Core、SqlSugar、FreeSql与Dapper的性能、功能与适用场景
.net
我是唐青枫2 天前
C#.NET 范围与索引(Range、Index)完全解析:语法、用法与最佳实践
c#·.net
深海潜水员2 天前
【MonoGame游戏开发】| 牧场物语实现 第一卷 : 农场基础实现 (下)
vscode·游戏·c#·.net·monogame
时光追逐者3 天前
Visual Studio 2026 现已正式发布,更快、更智能!
ide·c#·.net·visual studio