2010-05-09 9 views
6

Attualmente uso il seguente codice per recuperare e decomprimere i dati di stringa da Amazon C#:codice C# a gzip e caricare una stringa di Amazon S3

GetObjectRequest getObjectRequest = new GetObjectRequest().WithBucketName(bucketName).WithKey(key); 

using (S3Response getObjectResponse = client.GetObject(getObjectRequest)) 
{  
    using (Stream s = getObjectResponse.ResponseStream) 
    { 
     using (GZipStream gzipStream = new GZipStream(s, CompressionMode.Decompress)) 
     { 
      StreamReader Reader = new StreamReader(gzipStream, Encoding.Default);  
      string Html = Reader.ReadToEnd(); 
      parseFile(Html); 
     }  
    } 
} 

voglio invertire questa codice in modo che io possa comprimere e caricare stringa i dati su S3 senza essere scritti sul disco. Ho provato quanto segue, ma sto ottenendo un eccezione:

using (AmazonS3 client = Amazon.AWSClientFactory.CreateAmazonS3Client(AWSAccessKeyID, AWSSecretAccessKeyID)) 
{ 
    string awsPath = AWSS3PrefixPath + "/" + keyName+ ".htm.gz"; 

    byte[] buffer = Encoding.UTF8.GetBytes(content); 
    using (MemoryStream ms = new MemoryStream()) 
    { 
     using (GZipStream zip = new GZipStream(ms, CompressionMode.Compress)) 
     { 
      zip.Write(buffer, 0, buffer.Length); 

      PutObjectRequest request = new PutObjectRequest(); 
      request.InputStream = ms; 
      request.Key = awsPath; 
      request.BucketName = AWSS3BuckenName; 

      using (S3Response putResponse = client.PutObject(request)) 
      { 
       //process response 
      } 
     } 
    } 
} 

L'eccezione che sto ottenendo è:

non possono accedere a un flusso chiuso.

Cosa sto sbagliando?

EDIT:

L'eccezione è in corso sulla staffa di chiusura usando (GZipStream zip

traccia stack:

a System.IO.MemoryStream.Write (Byte [] buffer, Int32 offset, conteggio Int32)
a System.I O.Compression.DeflateStream.Dispose (booleano smaltimento) a System.IO.Stream.Close() in System.IO.Compression.GZipStream.Dispose (booleano smaltimento) a System.IO.Stream.Close()

+0

Dove si verifica l'eccezione? Puoi aggiungere una traccia stack completa? – dtb

+0

Grazie. Inoltre ho postato il dettaglio delle eccezioni – BigJoe714

risposta

11

è necessario svuotare e chiudere il GZipStream e ripristinare la posizione del MemoryStream a 0 prima di utilizzarlo come input per la richiesta:

MemoryStream ms = new MemoryStream(); 

using (GZipStream zip = new GZipStream(ms, CompressionMode.Compress, true)) 
{ 
    byte[] buffer = Encoding.UTF8.GetBytes(content); 
    zip.Write(buffer, 0, buffer.Length); 
    zip.Flush(); 
} 

ms.Position = 0; 

PutObjectRequest request = new PutObjectRequest(); 
request.InputStream = ms; 
request.Key = AWSS3PrefixPath + "/" + keyName+ ".htm.gz"; 
request.BucketName = AWSS3BuckenName; 

using (AmazonS3 client = Amazon.AWSClientFactory.CreateAmazonS3Client(
          AWSAccessKeyID, AWSSecretAccessKeyID)) 
using (S3Response putResponse = client.PutObject(request)) 
{ 
    //process response 
} 

potrebbe anche essere possibile utilizzare la GZipStream come input se in primo luogo riempi il MemoryStream con i dati, ma non l'ho mai provato.

+0

Grazie! ha funzionato – BigJoe714