在WCF调度消息之前,我在哪里可以找到MSMQ查找ID?

时间:2015-03-06 02:06:52

标签: wcf msmq netmsmqbinding

我们在IIS中托管了一个具有netMsmqBinding的WCF服务。在将消息发送到我们的服务之前,我们要记录MSMQ Lookup ID。在哪里可以找到这些信息?

我们在IErrorHandler中得到它,因为MsmqPoisonMessageException具有MessageLookupId属性。我们需要在请求开始时记录它,以便我们可以将异常与消息相关联。

我认为IDispatchMessageInspector会是正确的地方,但我似乎无法在AfterReceiveRequest方法中找到任何可以为我提供查找ID的属性。

1 个答案:

答案 0 :(得分:0)

到目前为止,我发现的唯一解决方案是对AfterReceiveRequest的Message参数使用反射。它有效,看起来很奇怪,它并没有作为一个公共财产浮出水面。

class MsmqLookupIdBehavior : IDispatchMessageInspector
{
    static PropertyInfo lookupIdPropertyInfo;

    static MsmqLookupIdBehavior()
    {
        try
        {
            var type = typeof(MsmqMessageProperty);
            lookupIdPropertyInfo = type.GetProperty("LookupId", BindingFlags.NonPublic | BindingFlags.Instance);
        }
        catch { }
    }

    public object AfterReceiveRequest(ref Message request, IClientChannel channel, InstanceContext instanceContext)
    {
        if (lookupIdPropertyInfo != null)
        {
            var lookupIds =
                request.Properties.Values
                .Where(p => p is MsmqMessageProperty)
                .Select(p => lookupIdPropertyInfo.GetValue(p))
                .Where(v => v is long)
                .Select(v => (long)v);

            foreach (var lookupId in lookupIds)
            {
                // Use lookupId here
            }
        }
        return null;
    }

    // The rest of IDispatchMessageInspector here, not relevant for this behavior
}