繁体   English   中英

使用 Boto3 在 S3 中设置 AWS 内容类型

[英]AWS Content Type Settings in S3 Using Boto3

我正在尝试使用 Amazon 的Boto3 SDK for Python 将 web 页面上传到 S3 存储桶。

我无法设置Content-Type 除了我使用以下代码指定的密钥之外,AWS 还不断为Content-Type创建一个新的元数据密钥:

# Upload a new file
data = open('index.html', 'rb')
x = s3.Bucket('website.com').put_object(Key='index.html', Body=data)
x.put(Metadata={'Content-Type': 'text/html'})

任何有关如何将Content-Type设置为text/html的指导将不胜感激。

Content-Type不是自定义元数据,而是Metadata的用途。 它有自己的属性,可以像这样设置:

bucket.put_object(Key='index.html', Body=data, ContentType='text/html')

注意: .put_object()可以设置的不仅仅是Content-Type 查看Boto3文档以了解其余部分。

您也可以使用upload_file()方法和ExtraArgs关键字(并将权限设置为World read):

import boto3
s3 = boto3.resource('s3')
s3.meta.client.upload_file('source_file_name.html', 'my.bucket.com', 'aws_file_name.html', ExtraArgs={'ContentType': "application/json", 'ACL': "public-read"} )

这里, data是一个打开的文件,而不是它的内容:

 # Upload a new file data = open('index.html', 'rb') 

要读取(二进制)文件:

import io

with io.open("index.html", mode="rb") as fd:
    data = fd.read()

这样会更好。

使用 Boto3 (2022)的示例 - 使用“ExtraArgs”参数

s3 = boto3.client('s3', aws_access_key_id = AWS_ACCESS_KEY_ID, aws_secret_access_key = AWS_SECRET_ACCESS_KEY, region_name = "us-east-1")
    
s3.upload_file(file_path, s3_bucket, file_name, ExtraArgs={'ContentType': "application/json"})

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM