将图像从 base64 转换为图像并保存在 Django 的数据库中
convert image from base64 to image and save in database in django
我正在尝试导出一个字符串base64,该字符串表示从画布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 将字符串导出到图像:
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 中删除data:
。
快速的谷歌搜索发现了一些设计用于解析python https://gist.github.com/zacharyvoase/5538178 中的数据uris的代码,另一个:dataurl.py
而不是这一行:image_data = base64.b64decode(imagen1)
使用此行:image_data = base64.b64decode(imagen1[22:] + b'=' * (-len(imagen1[22:]) % 4))
相关文章:
- 如何使用url加载程序在webpack中导入多个图像
- 如何将淡出图像添加到我的Django页面
- 为什么我不能在 Django Web 应用程序中使用客户端相机拍摄图像快照
- Django应用程序中的滚动图像
- 用jQuery替换Django中的图像
- 如何在Django中使用Dropzone为多个图像字段上传多个图像
- Django 在客户端上传之前调整图像大小
- 将图像从 base64 转换为图像并保存在 Django 的数据库中
- Django REST,上传的图像具有空值
- 使用 django 将图像从 html 表单下载到本地主机
- Django + skelJS / 静态文件问题 / 对 CSS 中图像的引用
- Django:除主页模板外,静态文件图像URL路径中断
- 通过JavaScript在Django中显示图像
- 使用Django提供随机图像
- 通过Ajax不断地从Django中获取图像
- 上传JavaScript生成的图像到Django
- Django - Javascript -禁用图像刷新缓存
- 如何将多个图像上传到服务器到Django应用程序中
- 如何在django-ckeditor上传图像时发送请求中的额外数据
- 如何使用Django后端在CKEDITOR中上传图像