Hprose 的 HTTP 客户端

setHeader 方法

  1. client.setHeader(name, value);

这个方法专门用于设置 HTTP 的头信息。

certificate 属性

该属性用于设置 HTTPS 客户端证书。但仅支持 APICloud 客户端。

Hprose 的 TCP 客户端

hprose for JavaScript 的 TCP 客户端是基于 chrome.sockets.tcp 实现的。因此它只可以在 chrome apps 或基于 ionic/cordova 的 android、iOS 应用中使用。

在 ionic/cordova 中使用时,需要安装 cordova-plugin-chrome-apps-sockets-tcp 插件。

noDelay 方法

  1. client.noDelay(value);
  2. client.noDelay();

用于设置在 TCP 上是否禁用 Nagle 算法。默认为 true

fullDuplex 方法

  1. client.fullDuplex(value);
  2. client.fullDuplex();

用于设置是否启用全双工通讯方式。在全双工通讯方式下,客户端发出调用请求后,不需要等待返回响应结果,就可以在同一个连接上发送下一个调用请求,而且在发送请求的过程中,可以同时接收服务器端返回的响应数据。也就是说,在该模式下,客户端和服务器之间的连接的利用率将会更高。尤其是在服务器返回响应较慢,或者服务器和客户端之间有推送请求时,客户端和服务器端只需要一个连接就足够了。而在半双工通讯模式下,则需要多个连接才可以。

不过该设置默认值为 false,原因是 hprose 旧版本的 TCP 服务器仅支持半双工通讯方式。你只有确认服务器端支持全双工通讯方式的情况下,才可以开启该选项,否则,在通讯中会得到异常信息。

maxPoolSize 方法

  1. client.maxPoolSize(value);
  2. client.maxPoolSize();

用于设置连接池中的最大连接数。默认值为 10。当开启全双工通讯方式后,可以将该值设置为 1。

poolTimeout 方法

  1. client.poolTimeout(value);
  2. client.poolTimeout();

用于设置连接池中的连接的空闲超时时间。默认值为 30000,单位是毫秒(ms)。

当连接池中的连接超过这个时间还没有被使用的情况下,将会自动关闭。

原文:

https://github.com/hprose/hprose-js/wiki/%E5%AE%A2%E6%88%B7%E7%AB%AF%E7%9A%84%E7%89%B9%E6%AE%8A%E8%AE%BE%E7%BD%AE