我们在IIS中托管了一个具有netMsmqBinding
的WCF服务。在将消息发送到我们的服务之前,我们要记录MSMQ Lookup ID。在哪里可以找到这些信息?
我们在IErrorHandler
中得到它,因为MsmqPoisonMessageException
具有MessageLookupId属性。我们需要在请求开始时记录它,以便我们可以将异常与消息相关联。
我认为IDispatchMessageInspector
会是正确的地方,但我似乎无法在AfterReceiveRequest方法中找到任何可以为我提供查找ID的属性。
答案 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
}