Problem z buforowaniem w WebClient / HttpClient
Opracowuję kod, aby sondować giełdę Bitstamp co 30 sekund. To jest kod, który mam:
public IObservable<string> Stream(Uri way, WebClient wc)
{
Func<IObserver<string>, Task> Fun = async Observer =>
{
var res = await wc.DownloadStringTaskAsync(way);
Observer.OnNext(value: res);
};
return Observable.Create<string>(Fun);
}
public IObservable<string> GetDelay(int secs)
{
var exe = TimeSpan.FromSeconds(secs);
return Observable.Empty<string>("x").Delay(exe);
}
Stream(new Uri("https://bitstamp.net/api/ticker"), new WebClient { }).Concat(GetDelay(30))
.Repeat(5).Subscribe(res => Debug.WriteLine("got result: {0}", res));
Problemem jestWebClient
(iHttpClient
też) oba zwracają buforowane wyniki po pierwszym wywołaniu, można je zobaczyć za pomocą tego samego znacznika czasu:
got result: {"high": "690.00", "last": "645.10", "timestamp": "1387715532" ... }
got result: {"high": "690.00", "last": "645.10", "timestamp": "1387715532" ... }
...
Nawet po wyłączeniu sieci zwracają wynik normalnie, więc oczywiście gdzieś go buforują. Dodanie czegoś takiego jak „cache = random” nie działa, ponieważ parametry żądania nie są dozwolone dla tickera na Bitstamp. OprawaHeaders[HttpRequestHeader.CacheControl] = "no-cache"
dlaWebRequest
też nie działa.
Jak mogę naprawić to dziwne zachowanie w pamięci podręcznej?