aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Framework/Servers/HttpServer/RestSessionService.cs19
-rw-r--r--OpenSim/Framework/Servers/HttpServer/SynchronousRestFormsRequester.cs1
2 files changed, 18 insertions, 2 deletions
diff --git a/OpenSim/Framework/Servers/HttpServer/RestSessionService.cs b/OpenSim/Framework/Servers/HttpServer/RestSessionService.cs
index 3f72c31..6c0aa46 100644
--- a/OpenSim/Framework/Servers/HttpServer/RestSessionService.cs
+++ b/OpenSim/Framework/Servers/HttpServer/RestSessionService.cs
@@ -88,6 +88,7 @@ namespace OpenSim.Framework.Servers.HttpServer
88 serializer.Serialize(writer, sobj); 88 serializer.Serialize(writer, sobj);
89 writer.Flush(); 89 writer.Flush();
90 } 90 }
91 buffer.Close();
91 92
92 int length = (int)buffer.Length; 93 int length = (int)buffer.Length;
93 request.ContentLength = length; 94 request.ContentLength = length;
@@ -99,8 +100,19 @@ namespace OpenSim.Framework.Servers.HttpServer
99 using (WebResponse resp = request.GetResponse()) 100 using (WebResponse resp = request.GetResponse())
100 { 101 {
101 XmlSerializer deserializer = new XmlSerializer(typeof(TResponse)); 102 XmlSerializer deserializer = new XmlSerializer(typeof(TResponse));
102 deserial = (TResponse)deserializer.Deserialize(resp.GetResponseStream()); 103 Stream respStream = null;
103 resp.Close(); 104 try
105 {
106 respStream = resp.GetResponseStream();
107 deserial = (TResponse)deserializer.Deserialize(respStream);
108 }
109 catch { }
110 finally
111 {
112 if (respStream != null)
113 respStream.Close();
114 resp.Close();
115 }
104 } 116 }
105 return deserial; 117 return deserial;
106 } 118 }
@@ -140,6 +152,7 @@ namespace OpenSim.Framework.Servers.HttpServer
140 serializer.Serialize(writer, sobj); 152 serializer.Serialize(writer, sobj);
141 writer.Flush(); 153 writer.Flush();
142 } 154 }
155 buffer.Close();
143 156
144 int length = (int)buffer.Length; 157 int length = (int)buffer.Length;
145 request.ContentLength = length; 158 request.ContentLength = length;
@@ -165,6 +178,8 @@ namespace OpenSim.Framework.Servers.HttpServer
165 // m_log.DebugFormat("[REST OBJECT POSTER RESPONSE]: Received {0}", reader.ReadToEnd()); 178 // m_log.DebugFormat("[REST OBJECT POSTER RESPONSE]: Received {0}", reader.ReadToEnd());
166 179
167 deserial = (TResponse)deserializer.Deserialize(stream); 180 deserial = (TResponse)deserializer.Deserialize(stream);
181 if (stream != null)
182 stream.Close();
168 183
169 if (deserial != null && ResponseCallback != null) 184 if (deserial != null && ResponseCallback != null)
170 { 185 {
diff --git a/OpenSim/Framework/Servers/HttpServer/SynchronousRestFormsRequester.cs b/OpenSim/Framework/Servers/HttpServer/SynchronousRestFormsRequester.cs
index 85622a1..e76d80e 100644
--- a/OpenSim/Framework/Servers/HttpServer/SynchronousRestFormsRequester.cs
+++ b/OpenSim/Framework/Servers/HttpServer/SynchronousRestFormsRequester.cs
@@ -62,6 +62,7 @@ namespace OpenSim.Framework.Servers.HttpServer
62 writer.Write(obj); 62 writer.Write(obj);
63 writer.Flush(); 63 writer.Flush();
64 } 64 }
65 buffer.Close();
65 66
66 length = (int)obj.Length; 67 length = (int)obj.Length;
67 request.ContentLength = length; 68 request.ContentLength = length;