利用Django实现文件上传
一、form表单的形式上传文件
1、路由
1 2 3 | urlpatterns = [ path( "upload/" , views.UploadView.as_view(),) ] |
2、视图
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | from django.views import View class UploadView(View): def get (self,reqeust): return render(reqeust, "index.html" ) # get 请求时,返回一个HTML页面 def post(self,reqeust): put_file = reqeust.FILES. get ( "put_file" ) #上传文件的post请求时,获取文件内容-->putfile print(put_file.name) #打印文件名 with open(put_file.name, "wb" ) as f: #将文件内容写入到文件中保存 for line in put_file: f.write(line) return HttpResponse( "上传成功!" ) #返回结果提示 |
3、模板index.html
1 2 3 4 5 6 7 8 | <h3>基于form表单的文件上传</h3> <form action= "/upload/" method= "post" enctype= "multipart/form-data" > <input type= "file" name= "put_file" > <input type= "submit" > </form> {#提交文件时,必须设置为这个参数:enctype= "multipart/form-data" #} |
二、Ajax的形式上传文件
1、后端代码和form表单上传的形式一样
2、前端代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | <h3>基于Ajax的文件上传</h3> <div> <input type= "file" class = "put_file" > <input type= "button" value= "提交" class = "btn" > <span class = "tip" ></span> {# 上传成功后的提示信息显示位置 #} </div> <script> //提交按钮的点击事件 $( ".btn" ).click(function () { //定义一个变量formdata,作为要发送的数据 var formdata = new FormData(); //将formdata组成键值对的形式,put_file=$(".put_file")[0].files[0],也就是:key=value,value是文件的内容 formdata.append( "put_file" ,$( ".put_file" )[0].files[0]); $.ajax({ url: "/upload/" , type: "post" , data:formdata, //要发送的数据,为上面准好的 --> formdata contentType: false , processData: false , success:function (res) { $( ".tip" ).html(res); //显示上传成功后的提示信息 } }) }) </script> |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现