gpt4 book ai didi

wcf - 使用代理在 WCF 中序列化委托(delegate)?

转载 作者:行者123 更新时间:2023-12-02 02:32:41 26 4
gpt4 key购买 nike

我有一个想法,但我需要帮助来实现它。

WCF 在其契约(Contract)中不支持委托(delegate)。相反,它有一个繁琐的回调契约(Contract)机制,我正在寻找一种方法来克服这个限制。

我考虑过使用 IDataContractSurrogate 将契约(Contract)中的每个委托(delegate)替换为将序列化到远程端点的 token 。在那里, token 将被反序列化为生成的委托(delegate)。这个生成的委托(delegate)将发送一个通用回调消息,其中封装了所有参数(调用委托(delegate)时使用的参数)。

通用回调消息将到达第一个端点,然后将使用参数调用原始委托(delegate)。

这是有目的的(简化的)序列:

  1. A 调用 B-pr​​oxy.Foo(callback)
  2. 回调通过 DelegateSurrogate 序列化。
  3. DelegateSurrogate 将委托(delegate)存储在专用的委托(delegate)存储中,并用 token 替换它
  4. 消息到达B的端点
  5. token 通过 DelegateSurrogate 反序列化
  6. DelegateSurrogate 构造生成的委托(delegate)
  7. B.Foo(generatedCallback) 被调用
  8. 稍后,B 正在调用 generatedCallback(args)
  9. generatedCallback(args) 在 A 的端点上调用一个专用的通用合约:CallbackContract-proxy.GenericCallback(args)
  10. 在 A 的端点调用 CallbackContract.GenericCallback(args)
  11. 从存储中检索原始回调并调用:callback(args)

我之前已经使用服务总线 (NServiceBus) 实现了这一点,但我想使这个想法适应 WCF,但我遇到了困难。我知道如何实现步骤 3、6、9 和 11。我还不知道如何连接 WCF 中的所有内容 - 特别是代理项部分。

就是这样 - 我希望我的问题是有道理的,并且这里的集体智慧能够帮助我建立这个。

这是我想要的解决方案的示例用法:

// client side
remoteSvc.GetEmployeeById(17, emp =>
{
employees.Add(emp);
logger.log("Result received");
});

// server side
public void GetEmployeeById(int id, Action<Employee> callback)
{
var emp = getEmpFromDb(id);
callback(emp);
}

最佳答案

实际上,在这种情况下,我会查看 Expression API。与委托(delegate)不同,Expression 可以在运行时解构。你不能默认序列化它们,但是一个lot of work已经在那个空间完成了。它也有点像许多 LINQ 提供程序在后台执行的操作,例如 WCF 数据服务。

当然,另一种方法是简单地使用lambda表达式作为RPC的钩子(Hook),这就是我描述的here .实现它的代码可以在 protobuf-net 树中免费获得。您可以通过使用属性将您的 token 与方法相关联并从 MethodInfo 获取属性来自定义它。

IMO,delegates 的问题在于它们与实现的耦合过于紧密,因此您不能在每一端都有不同的实现(这是一个常见的要求)。

表达式的优点是 lambda 仍然支持智能感知等,因此您可以执行以下操作:

client.Invoke(svc => svc.Foo(123, "abc"));

并从中分别获取Foo(MethodInfo)、123和“abc”,包括捕获的变量,ref/ out 等。一切正常。

关于wcf - 使用代理在 WCF 中序列化委托(delegate)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3128688/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com