django ajax传文件并保存至数据库

这篇博客详细介绍了如何在Django项目中利用Ajax实现文件上传,并将其保存至数据库。首先,文章讨论了Model中FileField的用法,接着讲述了如何结合easyui的filebox组件创建上传表单。此外,还探讨了Django的csrf保护机制以及在Ajax请求中设置processData和contentType的重要性。最后,重点讲解了后台处理文件上传的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Model

class Order(models.Model):
    drawing = models.FileField(null=False, upload_to='drawing/%Y/%m/%d')

表单

<form>
   <input type="file" id="a">
</form>
<script>
   let files = $('#a').filebox('files');
   let fd = new FormData();
   fd.append('order_id',{{order_id}})
   fd.append('file', files[0]);
   fd.append('csrfmiddlewaretoken', '{{ csrf_token }}');// post 提交的时候 django 会启动 csrf 验证
   $.ajax({
       url: '{% url 'order_detail' %}',
       type: 'post',
       data: fd,
       processData: false,  // 告诉jQuery不要去处理发送的数据
       contentType: false,   // 告诉jQuery不要去设置Content-Type请求头
       success: function () {
           alert('ok')
       }
   })
</script>

后台处理

from django.core.files import File
from django.http import JsonResponse

def order_detail(request):
   drawing = request.FILES.get('file')
   order_id = request.POST['order_id']
   if drawing:
   	Order.objects.get(pk=order_id).drawing.save(name=drawing.name,content=File(drawing))
   	return JsonResponse({})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值