Hprose 服务器端提供了几个事件,它们分别是:

  • onBeforeInvoke (beforeInvoke)
  • onAfterInvoke (afterInvoke)
  • onSendError (sendError)
    这三个事件所有的 Hprose 服务器都支持。

  • onSendHeader (sendHeader)
    这个事件仅 HTTP 服务器支持。

  • onAccept (accept)

  • onClose (close)
    这两个事件 Socket 和 WebSocket 服务器支持。

这些事件,括号外面的是以属性方式提供的,只需要将事件函数赋值给这些属性即可。括号里面的是以 on() 方法定义的。

例如:

  1. server.onBeforeInvoke = function(name, args, byref, context) {
  2. console.log(name, args, byref);
  3. }

  1. server.on('beforeInvoke', function(name, args, byref, context) {
  2. console.log(name, args, byref);
  3. });

都是可以的。

但这两种方式也是有区别的。

属性只能被赋值一个事件处理函数,而 on 方法则可以添加多个事件处理函数。

对于 onBeforeInvokeonAfterInvokeonSendError 这三个事件属性的事件处理函数允许有返回值。而 on 方法的事件处理函数没有返回值。

onBeforeInvokeonAfterInvoke 可以返回一个 promise 对象,当该 promise 对象变为失败(rejected)状态时,将会返回失败原因作为返回给客户端的错误信息。

onBeforeInvokeonAfterInvokeonSendError 都可以直接返回一个 Error 实例对象来作为返回给客户端的错误信息。

而在 'beforeInvoke', 'afterInvoke' 和 'sendError' 事件中,则只能通过抛出异常的方式来返回错误信息,当然通过抛出异常来返回错误信息给客户端的这种方式,onBeforeInvokeonAfterInvokeonSendError 事件属性也支持。

onBeforeInvoke (beforeInvoke) 事件

该事件在调用执行前触发,该事件的处理函数形式为:

  1. function(name, args, byref, context) { ... }

参数 name 是服务函数/方法名。参数 args 是调用的参数数组。参数 byref 表示是否是引用参数传递。参数 context 是该调用的上下文参数。

如果在该事件中抛出异常、返回错误对象、或者返回一个失败(rejected)状态的 promise 对象。则不再执行服务函数/方法。

onAfterInvoke (afterInvoke) 事件

该事件在调用执行后触发,该事件的处理函数形式为:

  1. function(name, args, byref, result, context) { ... }

参数 name 是服务函数/方法名。参数 args 是调用的参数数组。参数 byref 表示是否是引用参数传递。参数 result 是调用执行的结果。参数 context 是该调用的上下文参数。

如果在该事件中抛出异常、返回错误对象、或者返回一个失败(rejected)状态的 promise 对象。则不再返回结果 result,而是将错误信息返回给客户端。

onSendError (sendError) 事件

该事件在服务端发生错误时触发,该事件的处理函数形式为:

  1. function(error, context) { ... }

如果在该事件中抛出异常、返回错误对象、或者返回一个失败(rejected)状态的 promise 对象。则该错误会替代原来的错误信息返回给客户端。

当服务器与客户端之间发生网络中断性的错误时,仍然会触发该事件,但是不会有错误信息发送给客户端。

onSendHeader (sendHeader) 事件

该事件在服务器发送 HTTP 头时触发,该事件的处理函数形式为:

  1. function(context) { ... }

如果在该事件中抛出异常,则不再执行后序操作,直接返回异常信息给客户端。

onAccept (accept) 事件

该事件在 Socket 或 WebSocket 服务器接受客户端连接时触发,该事件的处理函数形式为:

  1. function(context) { ... }

如果在该事件中抛出异常,则会断开跟该客户端的连接。

onClose (close) 事件

该事件在 Socket 或 WebSocket 服务器跟客户端之间的连接关闭时触发,该事件的处理函数形式为:

  1. function(context) { ... }

该事件中抛出异常不会对服务器和客户端有任何影响。

原文: https://github.com/hprose/hprose-nodejs/wiki/Hprose-%E6%9C%8D%E5%8A%A1%E5%99%A8%E4%BA%8B%E4%BB%B6