微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 将图像从base64转换为图像并保存在django的数据库中

我正在尝试导出一个字符串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已损坏,我无法打开它,有人可以帮我解决这个问题吗?还是有其他方法可以做到这一点?非常感谢你.

解决方法:

我猜你需要剥离数据:关闭canvas.toDataURL();返回的数据URI.

一个快速谷歌搜索发现一些代码设计用于解析python https://gist.github.com/zacharyvoase/5538178和另一个dataurl.py中的数据uris

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐