8

Mi piacerebbe utilizzare HttpResponse.OutputStream insieme a ContentResult in modo che io possa Flush di volta in volta evitare di utilizzare troppa RAM da. Net.Come trasmettere correttamente i big data da MVC3 senza utilizzare troppa RAM?

Ma tutti gli esempi con MVC FileStreamResult, EmptyResult, FileResult, ActionResult, ContentResult mostrano il codice che ottiene tutti i dati in memoria e passa a uno di quelli. Anche un post suggerisce che restituire EmptyResult insieme all'utilizzo di HttpResponse.OutputStream è una cattiva idea. In quale altro modo posso farlo in MVC?

Qual è il modo giusto per organizzare l'output flusibile di big data (html o binario) dal server MVC?

Perché restituire EmptyResult o ContentResult o FileStreamResult una cattiva idea?

+0

Qualcuno ha informazioni sull'utilizzo di pipe stream menzionati in http://stackoverflow.com/a/2189635/37055 –

risposta

5

Si consiglia di utilizzare FileStreamResult se si dispone già di uno stream con cui lavorare. Un sacco di volte si può avere accesso al file, è necessario creare un flusso e quindi inviarlo al client.

System.IO.Stream iStream = null; 

// Buffer to read 10K bytes in chunk: 
byte[] buffer = new Byte[10000]; 

// Length of the file: 
int length; 

// Total bytes to read: 
long dataToRead; 

// Identify the file to download including its path. 
string filepath = "DownloadFileName"; 

// Identify the file name. 
string filename = System.IO.Path.GetFileName(filepath); 

try 
{ 
    // Open the file. 
    iStream = new System.IO.FileStream(filepath, System.IO.FileMode.Open, 
       System.IO.FileAccess.Read,System.IO.FileShare.Read); 


    // Total bytes to read: 
    dataToRead = iStream.Length; 

    Response.ContentType = "application/octet-stream"; 
    Response.AddHeader("Content-Disposition", "attachment; filename=" + filename); 

    // Read the bytes. 
    while (dataToRead > 0) 
    { 
     // Verify that the client is connected. 
     if (Response.IsClientConnected) 
     { 
      // Read the data in buffer. 
      length = iStream.Read(buffer, 0, 10000); 

      // Write the data to the current output stream. 
      Response.OutputStream.Write(buffer, 0, length); 

      // Flush the data to the HTML output. 
      Response.Flush(); 

      buffer= new Byte[10000]; 
      dataToRead = dataToRead - length; 
     } 
     else 
     { 
      //prevent infinite loop if user disconnects 
      dataToRead = -1; 
     } 
    } 
} 
catch (Exception ex) 
{ 
    // Trap the error, if any. 
    Response.Write("Error : " + ex.Message); 
} 
finally 
{ 
    if (iStream != null) 
    { 
     //Close the file. 
     iStream.Close(); 
    } 
    Response.Close(); 
} 

Here è la Microsoft articolo che spiega il codice precedente.