将 MultiValueDictKeyError 提高 request.FILES 以获取 base64 图像数据
Raise MultiValueDictKeyError by request.FILES to get base64 image data
实际上我需要获取 croppie javascript 库生成的 base64 图像数据。图像数据如下所示。

这是我的 HTML
<form action="{% url 'profile' %}" enctype="multipart/form-data" method="post" class="pic-upload-form" id="form">{% csrf_token %}
<div class="custom-file">
{% bootstrap_form form %}
</div>
<!-- Croppie area -->
<div id="upload-demo"></div>
<input type="hidden" id="image-data" name="imagebase64">
<button type="button" class="btn btn-outline-info btn-custom upload-result">save</button>
</form>
我将图像数据绑定到隐藏输入的 js 的最后一部分。
$('.upload-result').on('click', function (ev) {
$uploadCrop.croppie('result', {
type: 'base64',
size: 'viewport'
}).then(function (src) {
console.log(src);
// bind the image data to the hidden inpu id image-data
$('#image-data').attr('src', src);
$('#form').submit();
});
});
这是我的观点
def user_profile_view(request):
'''Handle the image of the user.'''
if request.method == 'POST':
form = UploadPicForm(request.POST, request.FILES)
if form.is_valid():
profile = form.save(commit=False)
# get the base64 image data
profile.image = request.FILES['imagebase64']
profile.save()
messages.success(request, 'your pic updated successfully.')
return HttpResponseRedirect(reverse('learning_path_tracker:home'))
else:
# form's user field populated by current user
form = UploadPicForm(initial={'user': request.user})
return render(request, 'users/uploadpic.html', {'form': form})
我认为图像数据不是字符串,这就是 request.FILES 引发错误的原因。但是我该如何解决这个问题,在此先感谢。
request.FILES
仅包含使用输入 type="file"
上传的文件。而您使用 type="hidden"
将图像数据作为 base64 发送,它将数据作为字符串发送,而不是作为文件发送。
因此,图像应该出现在 request.POST
而不是 request.FILES
中。
这样做:
profile.image = request.POST['imagebase64']
附带说明一下,您应该使用字典的 get()
方法而不是直接从字典访问键,因为如果请求的键不在字典中,它可以让您提供默认值。
profile.image = request.POST.get('imagebase64', "default value")
实际上我需要获取 croppie javascript 库生成的 base64 图像数据。图像数据如下所示。

这是我的 HTML
<form action="{% url 'profile' %}" enctype="multipart/form-data" method="post" class="pic-upload-form" id="form">{% csrf_token %}
<div class="custom-file">
{% bootstrap_form form %}
</div>
<!-- Croppie area -->
<div id="upload-demo"></div>
<input type="hidden" id="image-data" name="imagebase64">
<button type="button" class="btn btn-outline-info btn-custom upload-result">save</button>
</form>
我将图像数据绑定到隐藏输入的 js 的最后一部分。
$('.upload-result').on('click', function (ev) {
$uploadCrop.croppie('result', {
type: 'base64',
size: 'viewport'
}).then(function (src) {
console.log(src);
// bind the image data to the hidden inpu id image-data
$('#image-data').attr('src', src);
$('#form').submit();
});
});
这是我的观点
def user_profile_view(request):
'''Handle the image of the user.'''
if request.method == 'POST':
form = UploadPicForm(request.POST, request.FILES)
if form.is_valid():
profile = form.save(commit=False)
# get the base64 image data
profile.image = request.FILES['imagebase64']
profile.save()
messages.success(request, 'your pic updated successfully.')
return HttpResponseRedirect(reverse('learning_path_tracker:home'))
else:
# form's user field populated by current user
form = UploadPicForm(initial={'user': request.user})
return render(request, 'users/uploadpic.html', {'form': form})
我认为图像数据不是字符串,这就是 request.FILES 引发错误的原因。但是我该如何解决这个问题,在此先感谢。
request.FILES
仅包含使用输入 type="file"
上传的文件。而您使用 type="hidden"
将图像数据作为 base64 发送,它将数据作为字符串发送,而不是作为文件发送。
因此,图像应该出现在 request.POST
而不是 request.FILES
中。
这样做:
profile.image = request.POST['imagebase64']
附带说明一下,您应该使用字典的 get()
方法而不是直接从字典访问键,因为如果请求的键不在字典中,它可以让您提供默认值。
profile.image = request.POST.get('imagebase64', "default value")