0

我有一个简单的 WCF 服务,它公开一个 REST 端点,并从 BLOB 容器中获取文件。该服务将文件作为流返回。我偶然发现了这篇关于在做出响应后关闭流的帖子:

http://devdump.wordpress.com/2008/12/07/disposing-return-values/

这是我的代码:

public class FileService
{
     [OperationContract]
     [WebGet(UriTemplate = "{*url}")]
     public Stream ServeHttpRequest(string url)
     {                                
         var fileDir = Path.GetDirectoryName(url);
         var fileName = Path.GetFileName(url);
         var blobName = Path.Combine(fileDir, fileName);
         return getBlob(blobName);                                                                        
     }

     private Stream getBlob(string blobName)
     {
         var account = CloudStorageAccount.FromConfigurationSetting("ConnectingString");
         var client = account.CreateCloudBlobClient();
         var container = client.GetContainerReference("data");
         var blob = container.GetBlobReference(blobName);

         MemoryStream ms = new MemoryStream();           
         blob.DownloadToStream(ms);
         ms.Seek(0, SeekOrigin.Begin);                                   
         return ms;
      }
}

所以我有两个问题:

  1. 我应该遵循帖子中提到的模式吗?
  2. 如果我将返回类型更改为 Byte[],Cons/Pros 是什么?

(我的客户端是Silverlight 4.0,以防万一有什么影响)

4

2 回答 2

0

我会考虑将您的返回类型更改为byte[]. 它更整洁。

Streamimplements IDisposable,所以理论上你的方法的使用者需要在一个using块中调用你的代码:

using (var receivedStream = new FileService().ServeHttpRequest(someUrl))
{
   // do something with the stream
}

如果您的客户确实需要访问提供的东西Stream,那么一定要继续并返回它,但是通过返回 abyte[]您可以控制任何隐藏在幕后的非托管资源。

于 2011-09-22T10:59:34.807 回答
0

OperationBehaviorAttribute.AutoDisposeParameters 默认设置为 TRUE,这会在所有一次性的输入/输出上调用 dispose。所以一切正常。
此链接:
http
://devdump.wordpress.com/2008/12/07/disposing-return-values/ 解释了如何手动控制该过程。

于 2011-09-22T13:51:54.807 回答