【Django】AWS S3へアップロードしたファイルの圧縮方法がわかりません
解決したいこと
Djangoの本番環境において、S3にアップロードしたファイルを圧縮(サイズを小さく)したいのですが、処理方法がわかりません。
コードは下記のとおりです。
開発環境ではうまく処理されるのですが本番環境においてはAWSのS3のファイルを取得する際にエラーとなります。
下記の方法にこだわらず、本番環境での最適な処理がありましたらご教授いただきたいです。
よろしくお願い致します。
発生している問題・エラー
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte
該当するソースコード
file_name = xxxx.jpg
file_path = /xxxx/xxxxx/xxxx.jpg
ext = os.path.splitext(file_path)[1][1:]
if ext == 'jpg' or 'JPG':
ext = 'jpeg'
COMPRESS_QUALITY = 30 # 圧縮のクオリティ
if DEBUG: #開発環境
with open(file_path, 'rb') as inputfile:
# バイナリモードファイルをPILイメージで取得
im = Image.open(inputfile)
# 圧縮を実行
im_io = BytesIO()
im.save(im_io, ext, quality = COMPRESS_QUALITY)
with open(file_path, mode='wb') as outputfile:
# 出力ファイルに書き込み
outputfile.write(im_io.getvalue())
else:
#AWS(本番環境)
s3 = boto3.client('s3')
bucket_name=env('AWS_STORAGE_BUCKET_NAME')
obj = s3.get_object(Bucket=bucket_name, Key=file_path)
file = obj['Body'].read().decode() #エラー箇所
with open(file, 'rb') as inputfile:
# バイナリモードファイルをPILイメージで取得
im = Image.open(inputfile)
# 圧縮を実行
im_io = BytesIO()
im.save(im_io, ext, quality = COMPRESS_QUALITY)
s3.put_object(Bucket=bucket_name, Key=file_path, Body=im_io.getvalue(),)
参考にした記事
0