ASP.NETCoreAPI与Angular端读取流的问题,EventSource的响应具有MIME类型(“application/json”),但不是“text/event-stream”。
创始人
2024-09-17 18:31:06
0

需要使用HttpResponseStreamWriter而不是JsonWriter,以便在输出流的末尾添加换行符,并在返回的响应中正确设置文本/事件流MIME类型。

以下是一个示例:

ASP.NET Core API的控制器方法:

[HttpGet] [Produces("text/event-stream")] public async Task Get() { var response = HttpContext.Response; response.Headers.Add("Content-Type", "text/event-stream"); response.Headers.Add("Cache-Control", "no-cache");

var data = "data: Some data\n\n";
var buffer = Encoding.UTF8.GetBytes(data);

await response.Body.WriteAsync(buffer, 0, buffer.Length);
await response.Body.FlushAsync();

// Indicates end of stream
await response.Body.WriteAsync(Encoding.UTF8.GetBytes("event: end\r\n"), 0, Encoding.UTF8.GetByteCount("event: end\r\n"));

}

Angular端的服务方法应该使用EventSource进行订阅。以下是一个示例:

@Injectable({ providedIn: 'root' })

export class StreamingService { private source: EventSource; private apiUrl: string = 'https://localhost:44321/streaming/get';

subscribeToData(): Observable {
    return new Observable(observer => {
        this.source = new EventSource(this.apiUrl);

        this.source.addEventListener('error', error => {
            console.log('EventSource error: ', error);
            this.source.close();
            observer.error(error);
        });

        this.source.addEventListener('end', error => {
            console.log('EventSource closed');
            this.source.close();
            observer.complete();
        });

        this.source.onmessage = event => {
            const data = JSON.parse(event.data);
            observer.next(data);
        };
    })
}

}

这样就可以正确地使用EventSource与ASP.NET Core API中的数据流进行通信了。

相关内容

热门资讯

8分钟带你解说!吉祥填大坑有什... 8分钟带你解说!吉祥填大坑有什么诀窍(辅助挂)果然真的是有挂(有挂秘诀)-哔哩哔哩;小薇(透视辅助)...
第八分钟带你普及!战神辅助官网... 第八分钟带你普及!战神辅助官网(辅助挂)一直是有挂的(有挂规律)-哔哩哔哩;1、完成战神辅助官网的残...
第七分钟带你科普!微信黑科技辅... 第七分钟带你科普!微信黑科技辅助神器(辅助挂)其实真的有挂(确实有挂)-哔哩哔哩;详细微信黑科技辅助...
第4分钟带你开挂!家乡大贰智能... 第4分钟带你开挂!家乡大贰智能辅助(辅助挂)一直真的是有挂(有人有挂)-哔哩哔哩;1、让任何用户在无...
第4分钟带你透视!微信蜀山四川... 第4分钟带你透视!微信蜀山四川修改器先测试(辅助挂)其实真的是有挂(新版有挂)-哔哩哔哩;是一款可以...
三分钟带你了解!来物局潮汕麻雀... 三分钟带你了解!来物局潮汕麻雀(辅助挂)其实真的是有挂(有挂细节)-哔哩哔哩;亲真的是有正版授权,小...
热点推荐"白银胡乐辅... 热点推荐"白银胡乐辅助最简单三个步骤"开挂(透视)辅助平台(其实真的有挂的)-哔哩哔哩;人气非常高,...
1分钟带你得知!哥哥打大a辅助... 1分钟带你得知!哥哥打大a辅助神器(辅助挂)原来真的是有挂(有挂总结)-哔哩哔哩;1.哥哥打大a辅助...
一分钟揭秘"四川途游... 一分钟揭秘"四川途游辅助软件下载"开挂(透视)辅助安装(一直确实是有挂)-哔哩哔哩;相信小伙伴都知道...
十分钟带你介绍!四川麻将口诀顺... 十分钟带你介绍!四川麻将口诀顺口溜(辅助挂)果然真的有挂(有挂方式)-哔哩哔哩;1.四川麻将口诀顺口...