namespace System.Net
{
-#if MOONLIGHT
- internal class HttpWebResponse : WebResponse, ISerializable, IDisposable {
-#else
[Serializable]
public class HttpWebResponse : WebResponse, ISerializable, IDisposable {
-#endif
Uri uri;
WebHeaderCollection webHeaders;
CookieCollection cookieCollection;
}
}
+#if NET_4_5
+ virtual
+#endif
public CookieCollection Cookies {
get {
CheckDisposed ();
}
}
+#if NET_4_5
+ virtual
+#endif
public string Method {
get {
CheckDisposed ();
}
}
+#if NET_4_5
+ virtual
+#endif
public HttpStatusCode StatusCode {
get {
return statusCode;
}
}
+#if NET_4_5
+ virtual
+#endif
public string StatusDescription {
get {
CheckDisposed ();
CheckDisposed ();
if (stream == null)
return Stream.Null;
- if (0 == String.Compare (method, "HEAD", true)) // see par 4.3 & 9.4
+ if (string.Equals (method, "HEAD", StringComparison.OrdinalIgnoreCase)) // see par 4.3 & 9.4
return Stream.Null;
return stream;
void IDisposable.Dispose ()
{
Dispose (true);
- GC.SuppressFinalize (this);
}
-
+
+#if NET_4_0
+ protected override void Dispose (bool disposing)
+ {
+ this.disposed = true;
+ base.Dispose (true);
+ }
+#else
void Dispose (bool disposing)
{
this.disposed = true;
if (disposing)
Close ();
}
+#endif
private void CheckDisposed ()
{
if (webHeaders == null)
return;
- string value = webHeaders.Get ("Set-Cookie");
- if (value != null) {
- SetCookie (value);
+ //
+ // Don't terminate response reading on bad cookie value
+ //
+ string value;
+ try {
+ value = webHeaders.Get ("Set-Cookie");
+ if (value != null && SetCookie (value))
+ return;
+ } catch {
}
- value = webHeaders.Get ("Set-Cookie2");
- if (value != null) {
- SetCookie (value);
+ try {
+ value = webHeaders.Get ("Set-Cookie2");
+ if (value != null)
+ SetCookie (value);
+ } catch {
}
}
- void SetCookie (string header)
+ bool SetCookie (string header)
{
if (cookieCollection == null)
cookieCollection = new CookieCollection ();
+ bool at_least_one_set = false;
var parser = new CookieParser (header);
foreach (var cookie in parser.Parse ()) {
if (cookie.Domain == "") {
cookie.Domain = uri.Host;
- cookie.ExactDomain = true;
+ cookie.HasDomain = false;
}
- if (!CookieContainer.CheckSameOrigin (uri, cookie.Domain))
+ if (cookie.HasDomain &&
+ !CookieContainer.CheckSameOrigin (uri, cookie.Domain))
continue;
cookieCollection.Add (cookie);
- if (cookie_container != null)
+ if (cookie_container != null) {
cookie_container.Add (uri, cookie);
+ at_least_one_set = true;
+ }
}
+
+ return at_least_one_set;
}
}
}