Как я могу изменить сообщение в DuplexSessionChannel (tcpTransport) в пользовательском канале WCF? - PullRequest
0 голосов
/ 28 сентября 2011

Я реализую IDuplexSessionChannel на своем пользовательском канале, потому что я использую tcpTransport. В этом пользовательском канале я кеширую ответ на вызов службы (кэширование на стороне клиента). Но у него есть ошибки. В IRequestChannel все работает нормально. Как я могу изменить сообщение в методе TryMessage. Мой код:

public Message Receive(TimeSpan timeout)
    {
        Message response = null;
        response = CommunicationCacheManager.Get(_request.Headers.Action, _request);

        if (response == null)
        {
            response = this.InnerChannel.Receive(timeout);
            int cacheTimeout = 0;
            if (response.Headers.FindHeader(Constants.CacheTimeOutHeader.NAME, Constants.CacheTimeOutHeader.NAMESPACE) > -1)
            {
                cacheTimeout = response.Headers.GetHeader<int>(Constants.CacheTimeOutHeader.NAME, Constants.CacheTimeOutHeader.NAMESPACE);
            }
            if (cacheTimeout > 0 && response != null &&
                    !response.IsFault &&
                    !response.IsEmpty)
            {
                CommunicationCacheManager.Add(_request.Headers.Action, cacheTimeout, ref response);
            }
        }
        return response;
    }

    public Message Receive()
    {
        return this.InnerChannel.Receive();
    }

    public bool TryReceive(TimeSpan timeout, out Message message)
    {
        ThrowIfDisposedOrNotOpen();
        message = null;
        bool timedout = false;
        try
        {
            message = this.Receive(timeout);
        }
        catch (TimeoutException)
        {
            timedout = true;
        }
        return (!timedout);
    }

CacheManager работает. И я получаю ответ Кеша. Но попробуйте получить снова запустить и когда я посмотрю сообщение. Сообщение закрыто. Как я могу это исправить

1 Ответ

0 голосов
/ 18 октября 2011

Проблема решена.

Tcp Binding добавляет RelatesTo Header к сообщению.Таким образом, код изменен на

public Message Receive(TimeSpan timeout)
{
    Message response = null;
    response = CommunicationCacheManager.Get(_request.Headers.Action, _request);

    if (response == null)
    {
        response = this.InnerChannel.Receive(timeout);
        int cacheTimeout = 0;
        if (response.Headers.FindHeader(Constants.CacheTimeOutHeader.NAME, Constants.CacheTimeOutHeader.NAMESPACE) > -1)
        {
            cacheTimeout = response.Headers.GetHeader<int>(Constants.CacheTimeOutHeader.NAME, Constants.CacheTimeOutHeader.NAMESPACE);
        }
        if (cacheTimeout > 0 && response != null &&
                !response.IsFault &&
                !response.IsEmpty)
        {
            CommunicationCacheManager.Add(_request.Headers.Action, cacheTimeout, ref response);
        }
    }
    else
    {
       response.Headers.RelatesTo=_request.Header.MessageId;
    }
    return response;
}
...