在 ASP.NET Core 中将图像/ PDF 上传到 AWS Lambda 函数的 S3 存储桶时,可能会出现损坏的问题。这可能是由于二进制数据在上传期间未正确转换为 Base64 字符串导致的。解决方法是将二进制数据转换为 Base64 字符串后再上传。
以下是一个示例代码,演示将图像/ PDF 转换为 Base64 字符串并上传到 S3 存储桶中。
public async Task UploadToS3(IFormFile file)
{
if (file != null && file.Length > 0)
{
using (var ms = new MemoryStream())
{
// 将上传的文件复制到 MemoryStream 中
await file.CopyToAsync(ms);
// 将 MemoryStream 转换为 Base64 字符串
var fileBytes = ms.ToArray();
var imageString = Convert.ToBase64String(fileBytes);
// 设置上传到 S3 的文件名、文件类型和文件内容
var fileName = file.FileName;
var contentType = file.ContentType;
var fileContent = new MemoryStream(Encoding.UTF8.GetBytes(imageString));
// 将文件上传到 S3 上的指定存储桶中
var s3Client = new AmazonS3Client();
var s3Request = new PutObjectRequest
{
BucketName = "my-bucket",
Key = fileName,
ContentType = contentType,
InputStream = fileContent
};
var response = await s3Client.PutObjectAsync(s3Request);
}
}
}
在上传二进制数据到 AWS Lambda 的 S3 存储桶时,记得在 Lambda 函数中解码 Base64 字符串。这可以使用以下代码进行解码:
public async Task DownloadFromS3(string fileName)
{
// 下载指定文件名的文件
var s3Client = new AmazonS3Client();
var s3Request = new GetObjectRequest
{
BucketName = "my-bucket",
Key = fileName
};
var response = await s3Client.GetObjectAsync(s3Request);
// 从响应内容中获取文件内容
var s3Stream = response.ResponseStream;
var s3Buffer = new byte[response.ContentLength];
await s3Stream.ReadAsync(s3Buffer, 0, (int)response.ContentLength);
// 将文件内容转换为二进制数据
var base64