一、form表单上传文件

注意:

  1、form上需要加enctype="multipart/form-data"

  2、form提交的地址需要以/结尾

 def form_file(request):
     if request.method=="POST":
         file = request.FILES.get("file")
         with open(file.name,"wb") as f:
             for chunk in file.chunks():
                 f.write(chunk)
     return render(request,"form_file.html",locals())
 <form method="post" action="/form_file/" enctype="multipart/form-data">
     {% csrf_token %}
     <p><input type="file" name="file"></p>
     <p><input type="submit"></p>
 </form>

上传头像,用默认头像替换选择文件按钮:

     <p>
         {{ obj.img.label }}
         <label for="img"><img src="/static/img/default.png"></label>
         <input id="img" type="file" name="img">
     </p>

二、ajax上传文件

 def register(request):
     if request.method == "POST":
         form_obj = RegisterForm(request.POST)
         ret = {"status": 0, "msg": ""}
         if form_obj.is_valid():
             form_obj.cleaned_data.pop("re_pwd")
             avatar = request.FILES.get("avatar")
             models.UserInfo.objects.create(**form_obj.cleaned_data,avatar=avatar)
             return JsonResponse(ret)
         else:
             ret["status"] = 1
             ret["msg"] = form_obj.errors
             return JsonResponse(ret)
     form_obj = RegisterForm()
     return render(request,"register.html",locals())
 //ajax上传注册信息并获取错误信息
     $("#register-btn").click(function(){

         //ajax上传文件,data部分必须用对象
         var formData = new FormData();
         formData.append("username",$("#id_username").val());
         formData.append("password",$("#id_password").val());
         formData.append("re_pwd",$("#id_re_pwd").val());
         formData.append("email",$("#id_email").val());
         formData.append("avatar",$("#id_avatar")[0].files[0]);
         formData.append("csrfmiddlewaretoken",$("[name='csrfmiddlewaretoken']").val());

         $.ajax({
             url:"/register/",
             type:"post",
             //ajax上传文件需要加两个参数
             processData:false,
             contentType:false,
             data:formData,
             success:function(data){
                 if(data.status){
                     //如果有错误,则返回错误信息
                     $.each(data.msg,function(k,v){
                         //k是键,v是值,但是v是列表,错误信息可能有多个
                         $("#id_"+k).next("span").text(v[0]).parent().parent().addClass("has-error");
                     })
                 }else{
                     //如果没有错误,则跳转到指定页面
                     location.href = "/login/"
                 }
             }
         })
     })

 //输入框取得焦点时,清楚错误信息
     $("form input").focus(function(){
         $(this).next("span").text("").parent().parent().removeClass("has-error");
     });

三、iframe上传文件

Django之文件上传的更多相关文章

  1. python Django之文件上传

    python Django之文件上传 使用Django框架进行文件上传共分为俩种方式 一.方式一 通过form表单进行文件上传 #=================================== ...

  2. day56:django:csrf_token&文件上传

    目录 1.csrf介绍 2.django实现csrf_token认证 3.django实现文件上传 csrf介绍 什么是csrf? csrf:跨站请求伪造.攻击者通过HTTP请求将数据传送到服务器,从 ...

  3. Django(十七)文件上传

    http://www.cnblogs.com/wupeiqi/articles/5703697.html - 文件上传        - 普通上传        - 自定义页面上传按钮        ...

  4. 框架----Django之文件上传

    一.文件上传 1. 浏览器访问 http://127.0.0.1:8000/f1/ http://127.0.0.1:8000/f2/ 2. urls from django.conf.urls im ...

  5. Django的文件上传以及预览、存储

    思路: 文件上传通过前端的input标签,input设置display:none属性. 内容显示需要让前端通过<img>标签读取图片内容,可以通过<label>标签连接< ...

  6. Django实现文件上传功能

    文件上传 关注公众号"轻松学编程"了解更多. 1.创建上传文件夹 在static文件夹下创建uploads用于存储接收上传的文件 在settings中配置,MEDIA_ROOT=o ...

  7. Django普通文件上传

    前端代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  8. django 的文件上传

    template html(模板文件): <form enctype="multipart/form-data" method="POST" action ...

  9. Django处理文件上传File Uploads

    HttpRequest.FILES 表单上传的文件对象存储在类字典对象request.FILES中,表单格式需为multipart/form-data <form enctype="m ...

随机推荐

  1. Cursor: Pin S Wait On X In The Top 5 Wait Events

    Wait Events , Posted in: Technical Track Tags: Group Blog Posts, Oracle, Technical Blog Lately, wait ...

  2. JS检测浏览器是否最大化

    function isFullScreen (){     if(         window.outerHeight === screen.availHeight     ){         i ...

  3. Java高级篇(四)——反射

    之前写到了设计模式的代理模式,因为下一篇动态代理等内容需要用到反射的知识,所以在之前Java篇的基础上再写一篇有关反射的内容,还是以实际的程序为主,了解反射是做什么的.应该怎么用. 一.什么是反射 反 ...

  4. hbase集群搭建参考资料

    hadoop分布式集群搭建 http://www.ityouknow.com/hadoop/2017/07/24/hadoop-cluster-setup.html hbase分布式集群搭建: htt ...

  5. 初识:java虚拟机的内存划分

    什么是内存? 内存是计算机中的重要原件,临时存储区域,作用是运行程序.我们编写的程序是存放在硬盘中的,在硬盘中的程序是不会运行的,必须放进内存中才能运行,运行完毕后会清空内存.Java虚拟机要运行程序 ...

  6. 1 vmware 如何联网,以及行命令令初步

    VMware安装Linux(我安装的是ubuntu),没法上网,上网教程见:https://blog.csdn.net/qq_28090573/article/details/78730552 安装完 ...

  7. Centos查看tomcat状态及操作

    启动:一般是执行sh tomcat/bin/startup.sh 查看:执行ps -ef |grep tomcat 输出如下 www 5144 ...等等.Bootstrap start 说明tomc ...

  8. 控制结构(5): 必经之地(using)

    // 上一篇:局部化(localization) // 下一篇:最近最少使用(LRU) 基于语言提供的基本控制结构,更好地组织和表达程序,需要良好的控制结构. 前情回顾 上一周,我们谈到了分支/卫语句 ...

  9. Python基础知识5-递归函数、生成器

    函数执行流程* 递归Recursion 递归的性能  递归总结 递归练习: def fac(n): if n==1: return n return n*fac(n-1) def fac1(n, f= ...

  10. Shell命令-系统信息及显示之uname、hostname

    文件及内容处理 - uname.hostname 1. uname:显示系统信息 uname命令的功能说明 uname 命令用于显示系统信息.uname 可显示电脑以及操作系统的相关信息 uname命 ...