我正在尝试导出一个字符串base64,它表示从canvas html5拍摄的图像,这是javascript中的代码:
var canvas1 = $("#canvas1")[0];
var ctx1 = canvas1.getContext('2d');
dataURL1 = canvas1.toDataURL();
Whit ajax我将图像发送到服务器:
$.ajax({
type: "POST",
url: "/regiter_respuesta_agilidad/",
data:{
'imagen1': dataURL1,
}
});
在Django的views.py中,我使用base64.b64decode将字符串导出为image:
imagen1 = request.POST['imagen1']
image_data = base64.b64decode(imagen1)
imagene = ContentFile(image_data, 'imagen1.png')
answer = Answer(imagen=imagene)
在models.py中,我有:
class Answer(models.Model):
imagen = models.ImageField(upload_to=url)
问题是保存图像时,文件imagen1.png损坏,我无法打开它,有人可以解决这个问题吗?或者还有其他方法可以解决?非常感谢你。
最佳答案
我猜您需要从data:
返回的数据URI中删除canvas.toDataURL();
。
谷歌快速搜索找到了一些旨在解析python https://gist.github.com/zacharyvoase/5538178中的数据uri的代码,另一个代码:dataurl.py