asp.net中对网络文件的读取及处理

来源:互联网 发布:淘宝商家入驻协议 编辑:程序博客网 时间:2024/05/17 07:09

      最近做项目的时候,要求对音频文件做地址保护,找了一些资料,关于如果对地址做防盗链的处理还是比较多的,只是都是写好的组件,有些是开源的。但是根据项目要求,结合公司基础产品的情况,还是需要单独的来处理,就没有用那些组件。这就涉及到了对网络文件的读取。
     很自然的会想到HttpWebRequest和HttpWebResponse,不错,我也正是这么处理的。看看第一个版本:

  1.    private static byte[] getFileStream(string fileUrl) {
  2.             HttpWebRequest request = WebRequest.Create(fileUrl) as HttpWebRequest;
  3.             HttpWebResponse response = null;
  4.             MemoryStream msstream=new MemoryStream();
  5.             byte []buffer=new byte[1024];
  6.             if (request != null){
  7.                 try{
  8.                     response = request.GetResponse() as HttpWebResponse;
  9.                     if (response != null){
  10.                         if (response.StatusCode == HttpStatusCode.OK){
  11.                             Stream ms = response.GetResponseStream();
  12.                             while (ms.Read(buffer, 0, buffer.Length) > 0)
  13.                                 msstream.Write(buffer, 0, buffer.Length);
  14.                         }
  15.                     }
  16.                 }
  17.                 catch (Exception ex){
  18.                     ex.Message.ToString();
  19.                 }
  20.                 finally{
  21.                     response.Close();
  22.                 }
  23.             }
  24.             return msstream.GetBuffer();
  25.         }

      问题就出在发出请求后,得到的文件大小与实际的文件大小不一样,变大了。跟踪调试后,问题:
        1)跟踪调试,得到的结果是做了两次请求,但是并没有弹出两个下载文件对话框出来,而是只有一个。
        2)ms的内容长度与最后得到的msstream的长度是不一致的。
     对问题1很容易解决,问题2是怎么造成的?这才是真正的关键所在。当最后ms的内容长度小于所要读取的长度的时候,问题就出现了,buffer里面的内容有‘杂质’了,写进msstream里面的内容自然就不对了。直接用ms.Length做判断不就可以了,为什么要用上面的方式进行读取?那就先看看ms.Length在msdn里面怎么给出解释的:


     我并没有从Stream里面继承一个新类,而是直接用的Stream,length属性是用不了的(其它需要在继承类里面实现的熟悉也是一样)。换个思路:

    

  1.  static byte[] getInternetFileContent(string fileUlr){
  2.             HttpWebRequest request = null;
  3.             HttpWebResponse response = null;
  4.             MemoryStream msstream = new MemoryStream();
  5.             try{
  6.                 request = WebRequest.Create(fileUlr) as HttpWebRequest;
  7.                 response = request.GetResponse() as HttpWebResponse;
  8.                 if (response != null){
  9.                     if (response.StatusCode == HttpStatusCode.OK){
  10.                         Stream ms = response.GetResponseStream();
  11.                         long len = response.ContentLength;
  12.                         byte[] buffer = new byte[1024];
  13.                         long counter = 1024;
  14.                         long mod = len % counter;
  15.                         while (len / counter > 0){
  16.                             len -= counter;
  17.                             msstream.Write(buffer, 0, buffer.Length);
  18.                         }
  19.                         ms.Read(buffer, 0, (int)mod);
  20.                         msstream.Write(buffer, 0, (int)mod);
  21.                     }
  22.                 }
  23.             }
  24.             catch (Exception ex){
  25.                System.Diagnostics.Trace.Write(ex.Message);
  26.             }
  27.             finally{
  28.                 request = null;
  29.                 response = null;
  30.             }
  31.             return msstream.GetBuffer();
  32.         }

         增加了个计数器进行判断,最后一次读取的流就不会有‘杂质’了,得到的内容就是完整的文件内容,不会多出其它的东西。一切正常。