day060 ajax文件上传 json补充
请求头ContentType
文件上传时需要指定请求头,常见的类型有3种:
1.application/x-www-form-urlencoded(可以类比成在url后面拼接的形式发送,即a=1&b=2)
最常见的POST提交数据的方式.浏览器原生的form表单,如果不设置enctype,默认的提交格式为x-x-www-form-urlencoded. ajax默认也是他.
2.multipart/form-data(上传文件的格式)
这也是比较常见的POST的数据提交方式,我们使用表单上传文件时,必须让form表单的enctype等于multipart/form-data,form表单不支持发json类型的contenttype格式的数据,二ajax什么格式都可以发.
3.application / json(以json字符串的形式发送)
$('.c1').click(function(){
$.ajax({
url:'{% url ' home'%}',
type: post,
headers:{
X-CSRFToken:$.cookie('csrftoken'), #先记住,往后会讲
ContentType : ' json ',
},
data:JSON.stringify(
如果发送请求的格式是json格式,那么csrf_token必须写在hearders里面,
格式也是cookie, #contentType也是headers里面的一部分,写在里面外面都可以
) name:name,
}),
success:function(response){
函数执行体
}
})
基于form表单的文件上传 (from的作用一般是提示别人要提交数据)
模板部分
<form actions='' method='post' enctype='multipart/form-data'>
contenttype都是键值的形式发送数据,这种form_data的格式一般是把大数据一段一段隔开
用户名 :<input type='text' name='user'>
头像 : <input type='file' name='avatar'> #上传文件 ,如果不用form_data格式发送,那么默认的是urlencoded格式,这个标签的数据会组成avatar: 文件名字来进行发送
<input type='submit' >
</form>
视图部分
def index(request):
print(request.body) # 原始的请求体数据
print(request.GET) # GET请求数据
print(request.POST) # POST请求数据
print(request.FILES) # 上传的文件数据 return render(request,'index.html')
upload.py,内容如下:
def upload(request):
if request.method=='GET':
return render(request,'upload.html') else:
username=models.POST.get('user')
file_obj=models.FILES.get('file_obj') #获得文件数据对象 file_name=file_obj.name with open(file_name,'wb') as f:
#方式1:
for data in file_obj:
f.write(data)
#方式2:
for chunks in file_obj.chunks(): #chunks()默认一次返回大小为2.5M,是一个生成器
f.write(chunks)
基于ajax的文件上传(from用不用都没有关系,这里就是一个盒子的作用)
基于form表单上传文件 1.先导入jquery.js文件 2.再导入jquery.cookie.js文件 要不然会报错提示找不到jQuery文件,页面加载依上而下加载
html部分 要在form表单中写入enctype = “multipart/form-data”(设置请求头) 重点是views.py视图部分: import os def upload(request): if request.mthed == “GET”: return render(request,”upload.html”) else: file_obj = request.FILES.get(“file”) (得到一个文件句柄) file_name = file_obj.name (得到上传的文件的名字) path = os.path.join(“E:\上传的文件”,file_name) (设置放置文件的路径) with open(path,”wb”) as f: for i in file_obj: f.write(i) (循环遍历写入上传的文件) return HttpResponse(“ok”) 基于Ajax上传文件: 1. 我们只需要input输入框
两个输入框其中一个设置为type = “file”,用来获取文件
一个button按钮
设置相关的name和id值 2. 导入jQuery.cookie.js文件要在jQuery.js文件之后
3. 设置提交按钮的单击事件
$(“#btn”).click(function (){
var formdata = new FormData();(Ajax上传文件时,需要这个类型,它会将添加给他的键值对加工成formdata类型) var username = $(“$username”).val() (获取输入框的内容) var file = $(“#file”)[0].files[0]; ($(“#file”)[0].files得到的是一个文件列表,[0]取第一 项)
formdata.append(“username”,username);
formdata.append(“file”,file); (在formdata对象中添加数据)
$.ajax({
url:”{% url ‘upload’ %}”,
type:”post”,
headers:{"X-CSRFToken":$.cookie("csrftoken")},}) (设置请求头,通过post请求, csrf_token) processData:false, (不处理数据)
contentType:false, (不设置内容类型)
data:formdata, (将添加好数据的formdata放到data)
success:function(request){ }
}) 这两个前端共用同一个views.py的方法即可但是要注意name对应的值要一样要不然取不到值,报错
模板
<form> #用不用form没关系,这里就是个盒子的作用,一般写form标签是为了提示别人,这个地方的内容是要提交的
{% csrf_token %}
用户名 <input type="text" id="user">
头像 <input type="file" id="avatar">
<input type="button" id="ajax-submit" value="ajax-submit">
</form> <script> $("#ajax-submit").click(function(){
var formdata=new FormData(); #ajax上传文件的时候,需要这个类型,它会将添加给它的键值对加工成formdata的类型
formdata.append("user",$("#user").val()); #添加键值的方法是append,键和值之间是逗号 formdata.append('crfmiddlewaretoken',$('[name=csrfmiddlewaretoken]').val());
formdata.append(avatar_img,$('#avatar')[0].files[0]);
$.ajax({
url: '',
type: 'post',
data: formdata,将添加好的formdata放到data里
processData:false, #不处理数据
contentData:false, #不设置内容类型
success :function(data){
console.log(data)
}
})
})
</script>
关于json
JSON指的是JavaScript对象表示法
JSON是轻量级的文本数据交换格式
JSON独立于语言
JSON具有自我描述性,更易理解
day060 ajax文件上传 json补充的更多相关文章
- Ajax(form表单文件上传、请求头之contentType、Ajax传递json数据、Ajax文件上传)
form表单文件上传 上菜 file_put.html <form action="" method="post" enctype="multi ...
- 兼容ie的jquery ajax文件上传
Ajax文件上传插件很多,但兼容性各不一样,许多是对ie不兼容的,另外项目中是要求将网页内容嵌入到桌面端应用的,这样就不允许带flash的上传插件了,如:jquery uploadify...悲剧 对 ...
- jQuery插件AjaxFileUpload实现ajax文件上传
转自:http://www.cnblogs.com/linjiqin/p/3530848.html jQuery插件AjaxFileUpload用来实现ajax文件上传,该插件使用非常简单,接下来写个 ...
- 转: 如何实现jQuery的Ajax文件上传
[PHP文件上传] 在开始之前,我觉得是有必要把通WEB上传文件的原理简单说一下的.实际上,在这里不管是PHP,JSP,还是ASP处理上传的文件,其实都是WEB早已把文件上传到服务器了,我们只是运用上 ...
- [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传
原文 [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传 Fine Uploader(http://fineuploader.com/)是一个实现 ajax 上传文件 ...
- php+ajax文件上传
php+ajax文件上传 html: <input id="user_real_name" class="input_show" type="t ...
- 使用ajax提交form表单,包括ajax文件上传【转载】
[使用ajax提交form表单,包括ajax文件上传] 前言 转载:作者:https://www.cnblogs.com/zhuxiaojie/p/4783939.html 使用ajax请求数据,很多 ...
- 使用ajax提交form表单,包括ajax文件上传 转http://www.cnblogs.com/zhuxiaojie/p/4783939.html
使用ajax提交form表单,包括ajax文件上传 前言 使用ajax请求数据,很多人都会,比如说: $.post(path,{data:data},function(data){ ... },&qu ...
- 表单文件上传,ajax文件上传
原创链接:http://www.cnblogs.com/yanqin/p/5345562.html html代码 index.jsp(表单文件上传) <form action="sh ...
随机推荐
- Django进阶之中间件
中间件简介 django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法. 在djang ...
- 浏览器 User-Agent相关知识
文章引用链接 http://www.360doc.com/content/12/1012/21/7662927_241124973.shtml
- [openjudge-搜索]城堡问题(The Castle)
题目描述 描述 图1是一个城堡的地形图.请你编写一个程序,计算城堡一共有多少房间,最大的房间有多大.城堡被分割成mn(m≤50,n≤50)个方块,每个方块可以有0~4面墙. 输入 程序从标准输入设备 ...
- 20165215 MySort的实现
MySort的实现 要求 模拟实现Linux下Sort -t : -k 2的功能 要有伪代码,产品代码,测试代码(注意测试用例的设计) import java.util.*; public class ...
- vue mandmobile ui实现三列列表的方法
vue mandmobile ui实现三列列表的方法 请问这种列表的要用那个组件好呢?Cellitem 只能用到两列,这个要三列的怎么弄?mand的好像没有listview,grid组件的 问了man ...
- uboot移植阶段二--3串口终结篇
2011-03-20 23:00:37 前天U-boot移植串口后,能成功显示数据. 今天的主要目的是再次进行U-boot移植.看是否成功.花了40分钟,很顺利. 接着就是要把之前有问题的U-boot ...
- python核心技术
基本语法 Python的设计目标之一是让代码具备高度的可阅读性.它设计时尽量使用其它语言经常使用的标点符号和英文单字,让代码看起来整洁美观.它不像其他的静态语言如C.Pascal那样需要重复书写声明语 ...
- Python+OpenCV图像处理(十五)—— 圆检测
简介: 1.霍夫圆变换的基本原理和霍夫线变换原理类似,只是点对应的二维极径.极角空间被三维的圆心和半径空间取代.在标准霍夫圆变换中,原图像的边缘图像的任意点对应的经过这个点的所有可能圆在三维空间用圆心 ...
- # NOI.AC省选赛 第五场T1 子集,与&最大值
NOI.AC省选赛 第五场T1 A. Mas的童年 题目链接 http://noi.ac/problem/309 思路 0x00 \(n^2\)的暴力挺简单的. ans=max(ans,xor[j-1 ...
- Qt Windows打开指定文件注意替换双斜杠为单斜杠
QProcess::startDetached(QString("explorer %1").arg(strFilePath)); 其中,在windows上使用时,strFileP ...