websocket - 如何使用 Web 套接字在 Angular 应用程序和 composer-rest-server 之间进行通信?
问题描述
当我生成 Hyperledger Composer REST 服务器时(请参阅https://hyperledger.github.io/composer/latest/integrating/getting-started-rest-api),我可以选择指定是否要通过 WebSockets 启用事件发布(是/否)。
使用命令
yo hyperledger-composer
我使用生成的休息服务器生成了一个角度应用程序。
我期望的是以下内容:
如果我没有通过 WebSockets 为 composer-rest-server 启用事件发布,那么 angular 应用程序(为此 composer-rest-server 生成)将使用正常的 http 请求来联系 composer-rest-server。
这个期望得到了满足。Angular 应用程序中的(自动生成的)文件 data.service.ts 使用正常的 http 请求来联系服务器。以下是该文件的摘录:
public getAll(ns: string): Observable<Type[]> {
console.log('GetAll ' + ns + ' to ' + this.actionUrl + ns);
return this.http.get(`${this.actionUrl}${ns}`)
.map(this.extractData)
.catch(this.handleError);
}
public getSingle(ns: string, id: string): Observable<Type> {
console.log('GetSingle ' + ns);
return this.http.get(this.actionUrl + ns + '/' + id + this.resolveSuffix)
.map(this.extractData)
.catch(this.handleError);
}
public add(ns: string, asset: Type): Observable<Type> {
console.log('Entered DataService add');
console.log('Add ' + ns);
console.log('asset', asset);
return this.http.post(this.actionUrl + ns, asset)
.map(this.extractData)
.catch(this.handleError);
}
我的另一个期望是:
如果我确实通过 WebSockets 为 composer-rest-server 启用事件发布,那么 Angular 应用程序(为此 composer-rest-server 生成)将使用 websockets 来联系 composer-rest-server。
这个期望没有得到满足。Angular 应用程序中的(自动生成的)文件 data.service.ts 看起来完全相同(与是否为启用或禁用 Web 套接字的 composer-rest-server 生成 Angular 应用程序无关)。也就是说,使用普通的 http 请求来联系服务器。
这是为什么?如果我想使用网络套接字(用“ws”代替“http”),我是否必须手动更改文件“data.service.ts”中的代码,或者我在这里遗漏了什么?
解决方案
是的,你会替代。所以你的 websockets 服务器在ws://localhost:3000
. 然后您使用 WS 客户端订阅事件(您可以wscat
用作 WS 客户端来测试 - 即发布事件然后看到客户端接收事件)。见https://hyperledger.github.io/composer/latest/integrating/publishing-events.html
或写类似:
var ws = new WebSocket('ws://www.your.server.com');
ws.on('message', function incoming(data) {
console.log(data);
});
// or
ws.onmessage = function (event) {
console.log(event.data);
}
ETC
推荐阅读
- javascript - NextJs 路由到具有不同查询的同一页面
- javascript - 数据未从 API [ReactJs] 加载到列表中
- postgresql - Postgres: - 从具有不同数据的文本列中获取特定格式的日期值
- javascript - 错误类型错误:过滤器[this.selectedSearch] 不是函数
- perl - 安装 ActiveState Perl 后 ppm 不起作用
- xml - 使用 Powershell 从 CSV 中提取数据以用于字段/函数
- c# - 下拉菜单显示主键而不是 ASP.NET 核心和 Razor 中的名称
- angular - 当前模块路径的子节点返回“未定义”
- c# - 用户角色被创建,但刷新网页时网站崩溃
- c# - 即使在发送消息后,ShowTypingMiddleware 仍然显示指示器