0

我正在使用带有 Ably .NET 实时库版本 1.2.1 的 VB.NET。我有一个包装类设置和管理 Ably。该类实现 ILoggerSink。它正在设置频道,如来自班级不同部分的这些片段所示:

Public Class Ably
    Implements IDisposable, ILoggerSink
.
.
Private WithEvents mChannel As IRealtimeChannel
Private Delegate Sub ReceiveMessageDelegate(ByVal m As Message)
Private Delegate Sub PublishCallbackDelegate(ByVal result As Boolean, ByVal einfo As ErrorInfo)
Private mPublishCallbackDelegate As PublishCallbackDelegate = AddressOf PublishCallback
Private mReceiveMessageDelegate As ReceiveMessageDelegate = AddressOf ReceiveMessage
.
.
Dim opt = New ClientOptions(Main.AblyConnectionKey) With {.EchoMessages = False, .LogLevel = LogLevel.Debug}
Dim art = New AblyRealtime(opt)
mChannel = art.Channels.Get(idstr)
mChannel.Subscribe(Sub(m) mReceiveMessageDelegate(m))
.
.
mChannel.Publish(mname, mdata, Sub(m, n) mPublishCallbackDelegate(m, n))

接口方法从这个定义开始:

Public Sub LogEvent(level As LogLevel, message As String) Implements ILoggerSink.LogEvent
'The rest of the sub here.

由此类管理的所有其他 Ably 事物都可以工作 - 附加到通道、发布消息和接收消息。该类获取 mChannel.StateChanged 和 mChannel.[Error] 事件。

LogEvent 方法永远不会被调用。我错过了什么?谢谢。

更新:接受的答案有效,这是我在任何文档中都错过的一件简单的事情。这是更正后的代码行:

Dim opt = New ClientOptions(Main.AblyConnectionKey) With {.EchoMessages = False, .LogLevel = LogLevel.Debug, .LogHander = Me}

同样值得注意的是这个类是一个单例。

4

1 回答 1

1

缺少的部分是您需要告诉库LoggerSink要使用哪个。

类似的东西Logger.LoggerSink = Me

您需要小心,因为 ablyLogger是静态的,整个程序只有一次实例。如果您要实例化多个Ably类的实例,这将是一个问题。

一般来说,无论如何建议您拥有 1 个 RealtimeClient 实例,因此您可能会对上面的代码感到满意。

于 2020-09-23T14:47:31.690 回答