我使用以下代码从Amazon S3
下载并上传图片。现在,在下载图像后,我想使用imagick library调整图像大小,但不将其写入磁盘。那么,我如何直接从响应流创建图像magick对象,我将从S3获取并在Amazon S3上上传。您可以在下面的代码中建议相同的更改吗?
另外,如何将其更改为http处理程序,该处理程序从查询字符串中获取key的值?
我已经注释掉了我的图像代码magick对象的原因是我确定如何编写它。
func main() {
file, err := os.Create("download_file")
if err != nil {
log.Fatal("Failed to create file", err)
}
defer file.Close()
downloader := s3manager.NewDownloader(session.New(&aws.Config{Region: aws.String(REGION_NAME)}))
numBytes, err := downloader.Download(file,
&s3.GetObjectInput{
Bucket: aws.String(BUCKET_NAME),
Key: aws.String(KEY),
})
if err != nil {
fmt.Println("Failed to download file", err)
return
}
fmt.Println("Downloaded file", file.Name(), numBytes, "bytes")
//mw := imagick.NewMagickWand()
// defer mw.Destroy()
// err = mw.ReadImage(file)
// if err != nil {
// panic(err)
// }
// using io.Pipe read/writer file contents.
reader, writer := io.Pipe()
go func() {
io.Copy(writer, file)
file.Close()
writer.Close()
}()
uploader := s3manager.NewUploader(session.New(&aws.Config{Region: aws.String(REGION_NAME)}))
result, err := uploader.Upload(&s3manager.UploadInput{
Body: reader,
Bucket: aws.String(BUCKET),
Key: aws.String(KEY),
})
if err != nil {
log.Fatalln("Failed to upload", err)
}
log.Println("Successfully uploaded to", result.Location)
fmt.Println("code ran successfully")
}
答案 0 :(得分:2)
如果您想更有效地下载大文件,则只需要一个DownloadManager。 DownloadManager需要WriterAt
(通常为os.File
),您必须通过[]byte
自行实现或使用内存中的文件。
如果直接获取对象,可以将其读入[]byte
,然后传递给ReadImageBlob
:
out, err := s3Client.GetObject(&s3.GetObjectInput{
Bucket: aws.String(BUCKET),
Key: aws.String(KEY),
})
if err != nil {
log.Fatal(err)
}
img, err := ioutil.ReadAll(out.Body)
if err != nil {
log.Fatal(err)
}
mw := imagick.NewMagickWand()
defer mw.Destroy()
err = mw.ReadImageBlob(img)
if err != nil {
log.Fatal(err)
}
...