この回答で概説されている方法を使用してリクエストのクローンを作成しようとしています: https://stackoverflow.com/a/18014515/406322
ただし、元のリクエストにコンテンツが含まれていると、ObjectDisposedExceptionが発生します。
HttpRequestMessageを確実に複製するにはどうすればよいですか?
これでうまくいくはずです:
public static async Task<HttpRequestMessage> CloneHttpRequestMessageAsync(HttpRequestMessage req)
{
HttpRequestMessage clone = new HttpRequestMessage(req.Method, req.RequestUri);
// Copy the request's content (via a MemoryStream) into the cloned object
var ms = new MemoryStream();
if (req.Content != null)
{
await req.Content.CopyToAsync(ms).ConfigureAwait(false);
ms.Position = 0;
clone.Content = new StreamContent(ms);
// Copy the content headers
if (req.Content.Headers != null)
foreach (var h in req.Content.Headers)
clone.Content.Headers.Add(h.Key, h.Value);
}
clone.Version = req.Version;
foreach (KeyValuePair<string, object> prop in req.Properties)
clone.Properties.Add(prop);
foreach (KeyValuePair<string, IEnumerable<string>> header in req.Headers)
clone.Headers.TryAddWithoutValidation(header.Key, header.Value);
return clone;
}
コンテンツに対してLoadIntoBufferAsyncを呼び出すと、コンテンツがHttpContentオブジェクト内にバッファリングされることを保証できます。残っている唯一の問題は、ストリームを読み取っても位置がリセットされないことです。そのため、ReadAsStreamAsyncを実行し、ストリームの位置を0に設定する必要があります。
私の例は、カルロスが示したものと非常に似ています...
private async Task<HttpResponseMessage> CloneResponseAsync(HttpResponseMessage response)
{
var newResponse = new HttpResponseMessage(response.StatusCode);
var ms = new MemoryStream();
foreach (var v in response.Headers) newResponse.Headers.TryAddWithoutValidation(v.Key, v.Value);
if (response.Content != null)
{
await response.Content.CopyToAsync(ms).ConfigureAwait(false);
ms.Position = 0;
newResponse.Content = new StreamContent(ms);
foreach (var v in response.Content.Headers) newResponse.Content.Headers.TryAddWithoutValidation(v.Key, v.Value);
}
return newResponse;
}
`` `