python+ajaxFileUpload 无刷新上传文件
需要准备文件
http://pan.baidu.com/s/1bp4N3nL qqi0
html
<script src="{% static 'js/jquery.js' %}"></script>
<script src="{% static 'js/ajaxfileupload.js' %}"></script>
<form class="form-horizontal" action="" enctype="multipart/form-data" method="post" name="adUpload" id="adUpload" accept-charset="utf-8">
<div class="col-sm-9 center-block">
<label class="col-sm-4 control-label">选择上传广告类型</label>
<div class="col-sm-5">
<label class="checkbox-inline">
<input type="radio" id="inlineCheckbox1" name="ad" onclick="adType(1)" checked value="1"> 视频
</label>
<label class="checkbox-inline">
<input type="radio" id="inlineCheckbox2" name="ad" onclick="adType(2)" value="2"> 图片
</label>
</div>
</div>
<br/><br/><br/>
<div class="col-sm-9 center-block">
<label for="inputPassword3" class="col-sm-4 control-label">选择excel文件</label>
<div class="col-sm-3">
{% csrf_token %}
<input type="file" name="file" id="file_upload" class="form-control">
</div>
<input type="button" onclick="ajaxExcelUpload()" class="control-label btn btn-info" value="上传" />
</div>
</form>
<script>
function ajaxExcelUpload(){
$('#up_pro').show();
//progress_dataUp();
var adType = $("input[type='radio']:checked").val();
$.ajaxFileUpload({
url: '/handleUpload/',
type:'POST',
data: {adType: adType },
secureuri: false,
fileElementId: 'file_upload',
dataType: 'json',
success: function (data, status) {
if(data['res'] == 1){
$('#up_pro').html(data['data']);
$('#up_pro').css('color','#5bc0de');
{# setTimeout(function(){#}
{# $('#up_pro').html('正在进行数据导入,请稍等 ...');#}
{# $('#up_pro').css('color','#333');#}
{# $('#up_pro').hide();#}
{# //location.reload();#}
{# },2000);#}
}
if(data['res'] == 0){
$('#up_pro').html('上传失败!'+data['data']);
$('#up_pro').css('color','#c00');
}
},
error: function (data, status, e) {
console.log(status);
$('#up_pro').html('上传失败!');
$('#up_pro').css('color','#c00');
setTimeout(function(){
$('#up_pro').html('数据导入中,请稍等 ...');
$('#up_pro').css('color','#333');
$('#up_pro').hide();
},2000);
}
});
}
</script>
views.py
@csrf_exempt
def handle_upload(request):
if request.method=="POST":
type = request.POST.get('adType',None)
file = request.FILES.get("file",None)
if file: # 处理附件上传到方法
try:
handle_upload_file(file)
except Exception as e:
pass
data = str(e)
res = 0
result = {'res': res,'data':data}
content = json.dumps(result)
return HttpResponse(content)
def handle_upload_file(filename):
"""
handle_upload_file 上传文件
"""
try:
path = os.path.dirname(os.path.dirname(__file__))+'/static/ad/upload/'
print path
if not os.path.exists(path):
os.makedirs(path)
destination = open(path+filename.name, 'wb+')
for chunk in filename.chunks():
destination.write(chunk)
destination.close()
res = 1
except Exception, e:
print e
res = 0
return res
需要注意的 data
使用ajaxFileUpload上传文件时,有时需要带参数提交,网上有很多资料说使用data,但其实要使用data带参数是需要修改的,否则后台是获取不到的
分析原因:
ajaxFileUpload为了实现无刷新异步提交文件,构建 iframe 然后创建form表单 再将要上传的文件写上去再提交.但是原代码 却没有处理data.所以这块内容需要我们自己加上去.
下面红色部分为修改ajaxFileUpload.js的三处地方:
备注:好像csdn代码中加颜色加粗 有问题这三处修改的地方我直接贴出来,位置看下面的代码,
①createUploadForm: function(id, fileElementId,data);
②jQuery(form).appendTo('body')的前面修改:
if (data) { for (var i in data) { $('<input type="hidden" name="' + i + '" value="' + data[i] + '" />').appendTo(form); } }
③var form = jQuery.createUploadForm(id, s.fileElementId,s.data);
百度云盘中文件已修改过可以直接使用
python+ajaxFileUpload 无刷新上传文件的更多相关文章
- jquery ajax php 无刷新上传文件 带 遮罩 进度条 效果的哟
在很多项目中都会叫用户上传东西这些的,自从接触了jquery 和ajax之后就不管做什么,首先都会想到这个,我这个人呢?是比较重视客户体验的,这次我这边负责的是后台板块,然后就有一块是要求用户上传照片 ...
- ajax +jsp+iframe无刷新上传文件[转]
http://hi.baidu.com/zj360202/blog/item/f23e3711f929c774cb80c475.html ajax jsp 无刷新上传文件 2009-10-26 16: ...
- web 开发之js---巧用iframe实现jsp无刷新上传文件
首先要说的就是 ajax 是无法实现上传文件的,可以想一下ajax与后台通信都是通过传递字符串,怎么能传递文件呢?其实出于安全考虑js是不能操作文件的,所以就不要再说用ajax来实现文件的上传了,这是 ...
- $_FILES参数详解及简单<form>表单无刷新上传文件
$_FILES:经由 HTTP POST 文件上传而提交至脚本的变量,类似于旧数组$HTTP_POST_FILES 数组(依然有效,但反对使用)详细信息可参阅 POST方法上传 $_FILES数组内容 ...
- jQuery+php+ajax实现无刷新上传文件功能
jQuery+php+ajax实现无刷新上传文件功能,还带有上传进度条动画效果,支持图片.视频等大文件上传. js代码 <script type='text/javascript' src='j ...
- Ajax 无刷新上传文件插件 uploadify 的使用
在表单中无法直接使用 Ajax 上传文件,解决的思路可以是使用插件无刷新地上传文件,返回文件上传后的地址,然后把该地址作为 Ajax 的参数传递给服务器端进行数据库处理.可以使用 uploadify ...
- ajax无刷新上传文件
网页上传文件最简单的方式就是通过表单上传了,但是在提交表单的时候会导致网页刷新,但有的时候我们不想网页刷新,有什么办法呢,我们可以使用ajax上传文件来做到这一点.只有ajax还不行,还需要JavaS ...
- js无刷新上传文件
传统的文件上传方式 <form action="" method="POST" enctype="multipart/form-data&quo ...
- 通过Ajax使用FormData对象无刷新上传文件
写在前面:本文说的这个方案有浏览器兼容性问题:所有主流浏览器的较新版本已经支持这个对象了,比如Chrome 7+.Firefox 4+.IE 10+.Opera 12+.Safari 5+,对兼容性比 ...
随机推荐
- sql 查询字段是中文/英文/数字 正则表达式
一.包含中文字符 select * from 表名 where 列名 like '%[吖-座]%' 二.包含英文字符 select * from 表名 where 列名 like '%[a-z]%' ...
- 关于git提示“warning: LF will be replaced by CRLF”终极解答
一.发现问题 windows平台下使用git add,git deploy 文件时经常出现“warning: LF will be replaced by CRLF” 的提示. 网上很多解决办法提到: ...
- leecode第九题(回文数)
class Solution { public: bool isPalindrome(int x) { ) return false; ;//这里使用long,也不判断溢出了,反正翻转不等就不是回文 ...
- angular7 + d3 显示svg
汇总一些之前没有注意到的问题 总体思路: app只是显示svg为主,接收后端推送的数据改变,显示变化后的svg. 因此,只用d3的数据绑定更新组件里<svg></svg>节点. ...
- Mac Anaconda 安装
下载地址 https://www.anaconda.com/download/#macos 选择对应的python 版本 安装 一路下一步 安装后打开如下 呵呵,此处装完,我的python 环境又从3 ...
- Unity --- MeshRenderer之网格合并
创建如图所示的对象结构,parent为空对象,然后将下面的代码挂载到parent对象上运行即可. using UnityEngine; using System.Collections; public ...
- oracle.exe 内存占用过大
现象: 明明各个schema 占用的磁盘空间都不大. oracle.exe 却占用了差不多 3G 的内存. 解决: 查了google,各种英文关键字没有找到原因. 最后,中文检索到了. https:/ ...
- 如何抓取Amazon大图
https://www.douban.com/note/277033391/ 進入到日本Amazon看到某些商品有預覽圖可以放大欣賞,當你想要右鍵下載卻發現只得到空白圖或白邊圖.縮圖.切割圖,究竟原圖 ...
- hdu-6035 Colorful Tree
题目意思是计算所有路径(n*(n-1)/2)经过的不同颜色的数目和. 这个数目和可以转化为每种颜色经过的路径数目的求和,而这个求和又等价于颜色总数*n*(n-1)/2-没有经过某种颜色的边的数量的求和 ...
- apiCloud 播放视频
api.openVideo({ url:'https://fabu.chenchaoweb.cn/./Uploads/5a3b72be2b102.mp4' (路径必须是完整路径) });