ASP.NET Core Web API 流式返回,逐字顯示-當前焦點

2023-04-23 22:19:36 來源:博客園

Websocket、SSE(Server-Sent Events)和長輪詢(Long Polling)都是用于網頁和服務端通信的技術。

Websocket是一種全雙工通信協議,能夠實現客戶端和服務端之間的實時通信。它基于TCP協議,并且允許服務器主動向客戶端推送數據,同時也允許客戶端向服務器發送數據。


(資料圖)

SSE是一種單向通信協議,允許服務器向客戶端推送數據,但不支持客戶端向服務器發送數據。SSE建立在HTTP協議上,通過在HTTP響應中使用特殊的Content-Type和事件流(event stream)格式來實現。

長輪詢是一種技術,客戶端向服務器發送一個請求,并且服務器保持連接打開直到有數據可以返回給客戶端。如果在指定的時間內沒有數據可用,則服務器會關閉連接,客戶端需要重新建立連接并再次發起請求。

New Bing聊天頁面是通過WebSocket進行通信。

Open AI的ChatGPT接口則是通過SSE協議由服務端推送數據

事實上,以上幾種方式包括長輪詢,都可以實現逐字顯示的效果。那還有沒有其他的辦法可以實現這種效果了呢?

流式響應

當客戶端返回流的時候,客戶端可以實時捕獲到返回的信息,并不需要等全部Response結束了再處理。

下面就用ASP.NET Core Web API作為服務端實現流式響應。

返回文本內容

服務端

[HttpPost("text")]public async Task Post(){    string filePath = "文檔.txt";    Response.ContentType = "application/octet-stream";    var reader = new StreamReader(filePath);    var buffer = new Memory(new char[5]);    int writeLength = 0;    //每次讀取5個字符寫入到流中    while ((writeLength = await reader.ReadBlockAsync(buffer)) > 0)    {        if (writeLength < buffer.Length)        {        buffer = buffer[..writeLength];        }        await Response.WriteAsync(buffer.ToString());        await Task.Delay(100);    }}

客戶端

C# HttpClient
public async void GetText(){    var url = "http://localhost:5000/config/text";    var client = new HttpClient();    using HttpRequestMessage httpRequestMessage = new HttpRequestMessage(HttpMethod.Post, url);    var response = await client.SendAsync(httpRequestMessage, HttpCompletionOption.ResponseHeadersRead);    await using var stream = await response.Content.ReadAsStreamAsync();    var bytes = new byte[20];    int writeLength = 0;    while ((writeLength = stream.Read(bytes, 0, bytes.Length)) > 0)    {    Console.Write(Encoding.UTF8.GetString(bytes, 0, writeLength));    }    Console.WriteLine();    Console.WriteLine("END");}

HttpCompletionOption枚舉有兩個值,默認情況下使用的是ResponseContentRead

ResponseContentRead:等到整個響應完成才完成操作

ResponseHeadersRead:一旦獲取到響應頭即完成操作,不用等到整個內容響應

js XMLHttpRequest
<script>    var div = document.getElementById("content")    var url = "http://localhost:5000/config/text"    var client = new XMLHttpRequest()    client.open("POST", url)    client.onprogress = function (progressEvent) {        div.innerText = progressEvent.target.responseText    }    client.onloadend = function (progressEvent) {        div.append("END")    }    client.send()</script>

用axios請求就是監聽onDownloadProgress 了。

瀏覽器是通過Response Header中的Content-Type來解析服務端響應體的。如果后端接口沒有設置Response.ContentType = "application/octet-stream"onprogress只會在響應全部完成后觸發。

返回圖片

服務端

[HttpGet("img")]public async Task Stream(){    string filePath = "pixelcity.png";    new FileExtensionContentTypeProvider().TryGetContentType(filePath, out string contentType);    Response.ContentType = contentType ?? "application/octet-stream";    var fileStream = System.IO.File.OpenRead(filePath);    var bytes = new byte[1024];    int writeLength = 0;    while ((writeLength = fileStream.Read(bytes, 0, bytes.Length)) > 0)    {        await Response.Body.WriteAsync(bytes, 0, writeLength);        await Task.Delay(100);    }}

關鍵詞:

相關文章

熱文推薦

ASP.NET Core Web API 流式返回,逐字顯示-當前焦點
ASP.NET Core Web API 流式返回,逐字顯示-當前焦點

Websocket、SSE(Server-SentEvents)和長輪詢(LongP......更多>

基于Canal實現MySQL 8.0 數據庫數據同步-當前快訊
基于Canal實現MySQL 8.0 數據庫數據同步-當前快訊

前言服務器說明|主機名稱|操作系統|說明||--|--|||192......更多>

即時看!Node工程的依賴包管理方式
即時看!Node工程的依賴包管理方式

在前端工程化中,JavaScript依賴包管理是非常重要的一......更多>

中南建設為子公司文昌中南、蕪湖榮眾合計擔保7952萬元 天天速看
中南建設為子公司文昌中南、蕪湖榮眾合計擔保7952萬元 天天速看

截至公告日,中南建設及控股子公司對外擔保余額為427......更多>

排行推薦

廣東統計局:一季度廣東實現地區生產總值突破3萬億,工業生產增速轉正|世界快報
廣東統計局:一季度廣東實現地區生產總值突破3萬億,工業生產增速轉正|世界快報
上證報中國證券網訊4月23日,廣東統計局發布2023年一... 更多>
全球微頭條丨我國已有20個省份、40余條線路開展車路協同智慧高速公路建設
全球微頭條丨我國已有20個省份、40余條線路開展車路協同智慧高速公路建設
新華社北京4月23日電(記者葉昊鳴)智慧高速公路是交... 更多>
生態環境部:今年一季度全國地表水水質提升
生態環境部:今年一季度全國地表水水質提升
上證報中國證券網訊據生態環境部4月23日消息,生態環... 更多>
第九章 無眠之夜
第九章 無眠之夜
【在這個被墮淵的侵蝕的世界,死亡,變得不再是一切的... 更多>
看熱訊:雅詩閣提前實現全球16萬套的管理目標
一季度,雅詩閣新簽超4000套單元,提前實現全球管理16... 更多>
熱資訊!國資委召開國有企業創建世界一流示范企業推進會
據國資委網站,國資委副主任翁杰明指出,示范企業下一... 更多>
海關總署副署長王令浚會見克羅地亞外交部國務秘書馬圖斯奇 當前焦點
據海關發布微信公眾號,海關總署副署長王令浚21日上午... 更多>
證監會核發首批企業債券注冊批文 短訊
據證監會官網,證監會對國家發展改革委移交的34個企業... 更多>
寧靜的快樂 每日快報
前幾天和朋友去看盆景。朋友隨口說了一句,這么小的一... 更多>
香港特首李家超訪問比亞迪深圳總部|頭條焦點
4月22日,香港特首李家超參觀了比亞迪深圳總部,乘坐... 更多>
熱消息:當AI已成往事,系統會自動再平衡:(第1023篇周策略)2023.04.23
$銀華天璣-悄悄盈(TIA05031)$$銀華天璣-年年紅(TIAA04... 更多>
人工智能和Ai產業鏈是一場財富的再分配
1:創業板左側第一個藍色圈處是2022年4 22-4 30號,... 更多>
財報季最后一周!海天味業、邁瑞醫療、五糧液業績將揭曉,你更期待哪一家?|一周財報前瞻|每日速訊
四月末,A股上市公司年報披露接近尾聲。同花順數據顯... 更多>
2023廣東省博物館五一展覽活動有哪些?
2023廣東省博物館五一展覽活動有哪些?一眼千萬年——... 更多>

捷達VS7什么平臺_捷達vs7是什么平臺

【快播報】后背毛囊炎怎么治好_后背

熱推薦:一年級家長會心得簡短100字

維生素e可以擦臉嗎有什么效果_維生

環球速遞!福建白水洋圖片_白水洋在

天天關注:暁_對于暁簡單介紹

當前熱點-晾鷹臺集蒙古諸部落慰勞遣

晾馬臺村_對于晾馬臺村簡單介紹

【安委辦動態】石湖蕩鎮恬潤新苑開

每日速讀!宇環數控:簽訂1.07億元日

精品视频在线观看一区二区三区| 精品人妻潮喷久久久又裸又黄 | 国产精品伦一区二区三级视频| aaa级精品久久久国产片| 亚洲AV无码一区二区三区久久精品| 99在线热视频只有精品免费| 久久精品国产999大香线焦| 三上悠亚精品一区二区久久| 日韩一区二区三区精品| 99re九精品视频在线视频| 中文字幕精品一区| 国产精品成人精品久久久| 国产精品线在线精品国语| 久9视频这里只有精品8| 亚洲国产精品嫩草影院| 91麻豆精品国产一级| 亚洲精品亚洲人成在线麻豆| 久久久久成人精品无码中文字幕 | 久久精品成人免费网站| 国产精品亚洲成在人线| 精品国产一级在线观看| 国产在线91精品入口| 亚洲欧洲国产精品香蕉网| 亚洲精品乱码久久久久久按摩 | 国精品午夜福利视频不卡| 亚洲精品中文字幕乱码三区 | 欧美精品久久久久久精品爆乳| 国产精品福利一区二区| 精品无码av一区二区三区| 3d动漫精品一区视频在线观看| 精品蜜臀久久久久99网站| 99久久国产综合精品五月天| 99久久做夜夜爱天天做精品| 成人区人妻精品一区二区三区 | 亚洲精品尤物yw在线影院| 国产精品内射久久久久欢欢 | 2020国产成人久久精品| 久久精品国产亚洲AV未满十八| 亚洲精品V天堂中文字幕| 九九99久久精品国产| 国产精品一区二区三区高清在线|