Django之文件上传
一、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之文件上传的更多相关文章
- python Django之文件上传
python Django之文件上传 使用Django框架进行文件上传共分为俩种方式 一.方式一 通过form表单进行文件上传 #=================================== ...
- day56:django:csrf_token&文件上传
目录 1.csrf介绍 2.django实现csrf_token认证 3.django实现文件上传 csrf介绍 什么是csrf? csrf:跨站请求伪造.攻击者通过HTTP请求将数据传送到服务器,从 ...
- Django(十七)文件上传
http://www.cnblogs.com/wupeiqi/articles/5703697.html - 文件上传 - 普通上传 - 自定义页面上传按钮 ...
- 框架----Django之文件上传
一.文件上传 1. 浏览器访问 http://127.0.0.1:8000/f1/ http://127.0.0.1:8000/f2/ 2. urls from django.conf.urls im ...
- Django的文件上传以及预览、存储
思路: 文件上传通过前端的input标签,input设置display:none属性. 内容显示需要让前端通过<img>标签读取图片内容,可以通过<label>标签连接< ...
- Django实现文件上传功能
文件上传 关注公众号"轻松学编程"了解更多. 1.创建上传文件夹 在static文件夹下创建uploads用于存储接收上传的文件 在settings中配置,MEDIA_ROOT=o ...
- Django普通文件上传
前端代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...
- django 的文件上传
template html(模板文件): <form enctype="multipart/form-data" method="POST" action ...
- Django处理文件上传File Uploads
HttpRequest.FILES 表单上传的文件对象存储在类字典对象request.FILES中,表单格式需为multipart/form-data <form enctype="m ...
随机推荐
- Openwrt无线中继设置并访问外网
Openwrt无线中继设置并访问外网 本篇博文参考来自:http://blog.csdn.net/pifangsione/article/details/13162023 配置目标 主路由器使用AP模 ...
- 第五章:Realm
一,UserRealm 1,UserRealm父类AuthorizingRealm将获取Subject相关信息分成两步: 1.1,获取身份验证信息(doGetAuthenticationInfo): ...
- 关于wxpython多线程研究包括(import Publisher等错误研究)
作为一个自动化测试人员,开发基本的应用桌面程序是必须的!最近在研究wxpython相关知识,目前看到多线程一块,发现官方文档介绍说:"在线程中不能修改修改窗口属性!",但是实际情况 ...
- UIGestureRecognizer - BNR
继续上篇UITouch - BNR.该篇将实现线条选择.移动和删除操作. UIGestureRecognizer有一系列子类,每一个子类都用于识别特定的手势.当识别出一个手势时,手势识别器会拦截视图的 ...
- 【第二篇】ASP.NET MVC快速入门之数据注解(MVC5+EF6)
目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...
- Kali Linux Netcat 学习 与 网络攻击
Netcat 网络攻击 以及 应用 1.用Netcat进行黑客攻击第1部分:基础知识 Netcat是一个很好的网络实用程序,用于使用TCP和UPD协议读取和写入网络连接.Netcat通常被称为网络工具 ...
- mybatis mapper映射文件全解
目录 select.update.delete.insert 设置参数类型以及取值 基本数据类型 对象数据类型 map数据类型 #{ } 和 ${ } 的区别 ResultMap Auto-map ...
- js-模块化(三大模块化规范)
###1. JS模块化 * 模块化的理解 * 什么是模块? * 将一个复杂的程序依据一定的规则(规范)封装成几个块(文件), 并进行组合在一起 * 块的内部数据/实现是私有的, 只是向外部 ...
- sql sever基本命令
创建表: create table stu_info( id ,) not null primary key clustered, name ) not null, score numeric not ...
- Shell命令-文件及内容处理之more、less
文件及内容处理 - more.less 1. more:分页显示文件内容 more命令的功能说明 more 命令类似 cat,不过会以一页一页的形式显示,更方便使用者逐页阅读,而最基本的指令就是按空白 ...