提问人:Flacype 提问时间:7/10/2020 最后编辑:Flacype 更新时间:7/10/2020 访问量:109
图片上传错误“检查表单上的编码类型”。
Image upload error 'Check the encoding type on the form.'
问:
在我的项目中,我需要上传一张图片作为玩家的头像,如我的 models.py 所示:
class Player(models.Model):
number = models.IntegerField()
photo = models.ImageField(upload_to=upload_path, null=True, blank=True)
firstname = models.CharField(max_length=24)
lastname = models.CharField(max_length=24)
tag = models.CharField(max_length=8, blank=True)
color = models.CharField(max_length=10, null=True, blank=True)
selected = models.BooleanField(null = False, blank=True)
post = models.ForeignKey(Post, on_delete=models.SET_NULL, null=True)
def __str__(self):
return "#{}".format(
self.number,
)
我正在使用 angular 发送我的图像:
<input
type="file"
(change)="onNewPlayerPhotoChanged($event)"
accept="image/jpeg, image/png, image/jpg"
/>
& 在我的打字稿中
onNewPlayerPhotoChanged(event) {
this.newPlayerPhoto = event.target.files[0];
}
然后在我的提交按钮上,我得到了
createPlayer() {
this.newPlayer.selected = false;
this.newPlayer.photo = this.newPlayerPhoto;
this.newPlayer.post_id = parseInt(this.newPlayerPost, 10);
this.playerService.create(this.newPlayer).subscribe(
res => {
this.getPlayerList();
this.openNewModal = false;
this.alertService.success('Joueur créé avec succès !');
setTimeout(() => this.alertService.clear(), 2000);
},
error => {
this.alertService.error(error);
setTimeout(() => this.alertService.clear(), 2000);
}
);
}
但是我收到错误:照片:[“提交的数据不是文件。检查表单上的编码类型。
这是我的**views.py:**
class PlayerViewSet(viewsets.ModelViewSet):
"""
API endpoint that allows Player to be viewed or edited.
"""
parser_classes = [JSONParser]
queryset = Player.objects.all()
serializer_class = PlayerSerializer
permission_classes = [IsAuthenticated, HasPermission, ]
def post(self, request, *args, **kwargs):
return HttpResponse({"message":request.FILES}, status=200)
print(request.FILES)
print(request.data)
photo = request.FILES['photo']
firstname = request.data['firstname']
lastname = request.data['lastname']
number = request.data['number']
tag = request.data['tag']
color = request.data['color']
selected = request.data['selected']
post = request.data['post']
Player.objects.create(photo=photo, firstname=firstname, lastname=lastname, number=number, tag=tag, color=color,
selected=selected, post=post)
return HttpResponse({'message':"Player created"}, status=200)
&我的 serializers.py :
class PlayerSerializer(serializers.ModelSerializer):
post = PostSerializer(many=False, read_only=True)
post_id = serializers.PrimaryKeyRelatedField(source='post', write_only=True, queryset=Post.objects.all(),)
class Meta:
model = Player
fields = '__all__'
我按照该教程 https://www.youtube.com/watch?v=-36YauTh4Ts 但他没有发现该错误,
如果有人能帮忙,将不胜感激。 谢谢!
编辑:我尝试在我的视图中使用FileUploadParser和MultiPartParser作为解析器,但它们都不起作用,FileUploadParser会返回我一个错误,说需要文件名,MultiPartParser会返回我一个错误,提示他正在接收JSON。
答: 暂无答案
评论