Javascript Python flask上载base64图像
我正在尝试用JS(use)和Python(Flask)创建裁剪和调整大小工具 Cropit返回了裁剪图像的base64,我通过AJAX将其发送到服务器,但无法保存 阿贾克斯:Javascript Python flask上载base64图像,javascript,python,ajax,flask,base64,Javascript,Python,Ajax,Flask,Base64,我正在尝试用JS(use)和Python(Flask)创建裁剪和调整大小工具 Cropit返回了裁剪图像的base64,我通过AJAX将其发送到服务器,但无法保存 阿贾克斯: $.ajax({ type: 'GET', url: '/api/saver', data: 'file=' + imageData, enctype: 'multipart/form-data'
$.ajax({
type: 'GET',
url: '/api/saver',
data: 'file=' + imageData,
enctype: 'multipart/form-data',
processData: false, // Important!
contentType: 'application/json;charset=UTF-8',
cache: false,
success: function(msg){
console.log('Done')
}
});
在服务器端
@app.route('/api/saver/', methods=['GET', 'POST'])
def api_save_base64_image():
if request.method == 'GET':
file = request.args.get('file')
starter = file.find(',')
image_data = file[starter+1:]
image_data = bytes(image_data, encoding="ascii")
with open('.../image.jpg', 'wb') as fh:
fh.write(base64.decodebytes(image_data))
return 'ok'
return 'error
返回时没有异常,但image.jpg已损坏(为空)
如何通过Flask从客户端保存图像?这有点棘手:)但是cropit
将图像导出为png
数据:图像/png
因此,如果您将代码更改为此,它将起作用:)
要更改格式,可以执行以下操作:
import base64
from io import BytesIO
from PIL import Image
...
image_data = bytes(image_data, encoding="ascii")
im = Image.open(BytesIO(base64.b64decode(image_data)))
im.save('image.jpg')
...
您可以在检查base64中找到此代码及其数据!代码使用正确的数据。您知道通过flask保存裁剪的base64图像的更简单方法吗?更改了图像格式,但结果相同-请检查答案!我更新了它,您可以在我的GitHubs Gitsreturn binascii.a2b_base64(s)binascii中找到并测试它。错误:填充不正确或-raise IOError(读取图像文件时消息+“OSError”:读取图像时数据流中断file@KonstantinRusanov谢谢,base64.encodebytes()方法适合我。
import base64
from io import BytesIO
from PIL import Image
...
image_data = bytes(image_data, encoding="ascii")
im = Image.open(BytesIO(base64.b64decode(image_data)))
im.save('image.jpg')
...