需要准备文件

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 无刷新上传文件的更多相关文章

  1. jquery ajax php 无刷新上传文件 带 遮罩 进度条 效果的哟

    在很多项目中都会叫用户上传东西这些的,自从接触了jquery 和ajax之后就不管做什么,首先都会想到这个,我这个人呢?是比较重视客户体验的,这次我这边负责的是后台板块,然后就有一块是要求用户上传照片 ...

  2. ajax +jsp+iframe无刷新上传文件[转]

    http://hi.baidu.com/zj360202/blog/item/f23e3711f929c774cb80c475.html ajax jsp 无刷新上传文件 2009-10-26 16: ...

  3. web 开发之js---巧用iframe实现jsp无刷新上传文件

    首先要说的就是 ajax 是无法实现上传文件的,可以想一下ajax与后台通信都是通过传递字符串,怎么能传递文件呢?其实出于安全考虑js是不能操作文件的,所以就不要再说用ajax来实现文件的上传了,这是 ...

  4. $_FILES参数详解及简单<form>表单无刷新上传文件

    $_FILES:经由 HTTP POST 文件上传而提交至脚本的变量,类似于旧数组$HTTP_POST_FILES 数组(依然有效,但反对使用)详细信息可参阅 POST方法上传 $_FILES数组内容 ...

  5. jQuery+php+ajax实现无刷新上传文件功能

    jQuery+php+ajax实现无刷新上传文件功能,还带有上传进度条动画效果,支持图片.视频等大文件上传. js代码 <script type='text/javascript' src='j ...

  6. Ajax 无刷新上传文件插件 uploadify 的使用

    在表单中无法直接使用 Ajax 上传文件,解决的思路可以是使用插件无刷新地上传文件,返回文件上传后的地址,然后把该地址作为 Ajax 的参数传递给服务器端进行数据库处理.可以使用 uploadify ...

  7. ajax无刷新上传文件

    网页上传文件最简单的方式就是通过表单上传了,但是在提交表单的时候会导致网页刷新,但有的时候我们不想网页刷新,有什么办法呢,我们可以使用ajax上传文件来做到这一点.只有ajax还不行,还需要JavaS ...

  8. js无刷新上传文件

    传统的文件上传方式 <form action="" method="POST" enctype="multipart/form-data&quo ...

  9. 通过Ajax使用FormData对象无刷新上传文件

    写在前面:本文说的这个方案有浏览器兼容性问题:所有主流浏览器的较新版本已经支持这个对象了,比如Chrome 7+.Firefox 4+.IE 10+.Opera 12+.Safari 5+,对兼容性比 ...

随机推荐

  1. RedHat(Linux)下安装Python3步骤

    1. 下载解压.$ wget https://www.python.org/ftp/python/3.4.1/Python-3.4.1.tgz$ tar zxvf Python-3.4.1.tgz 2 ...

  2. SQLServer 中的存储过程中判断临时表是否存在,存在则删除临时表

    IF OBJECT_ID('TEMPDB..#BCROSSREFERENCE ') IS NOT NULL DROP TABLE #BCROSSREFERENCE IF OBJECT_ID('TEMP ...

  3. mysql基本知识总结

    第一天 create database act_web character set utf8; : 创建数据库并设立编码(命令中是不允许使用“-”的) '; :创建用户并设立密码 grant all ...

  4. jmeter5.0之源码导入 IntelliJ IDEA

    IDEA 编译 Jmeter 1.下载并解压 jmeter 源码 http://archive.apache.org/dist/jmeter/source/ 下载源码后解压『Jmeter』,我这边下载 ...

  5. d3 parse字符串形式的xml svg and append to element

    参考这个方法,但不想修改d3 https://gist.github.com/biovisualize/373c6216b5634327099a 虽然也绕了点弯,但还算很快了,比较满意,也学到了,记下 ...

  6. 【java】Comparator的用法

    文章转载自: http://blog.csdn.net/u012250875/article/details/55126531 1.为什么写? comparator 是javase中的接口,位于jav ...

  7. Codeforces 374C - Inna and Dima

    374C - Inna and Dima 思路:dfs+记忆化搜索 代码: #include<bits/stdc++.h> using namespace std; #define ll ...

  8. Oracle:新增用户登录提示“ORA-04098:触发器‘GD.ON_LOGON_TRIGGER’无效且未通过重新验证”

    接着上一篇创建一个只有查看权限的用户,在测试环境,新建账号后尝试登录,提示如下: 1.看提示是base库的触发器有问题了,所以先定位到这个触发器 SELECT * FROM DBA_OBJECTS W ...

  9. tstringlist详细用法

    TStringList 类是在Delphi使用最厂的一个对像,我们这里一起来看看 TStringList 的详细用法. 先把要讨论的几个属性列出来:1.CommaText2.Delimiter &am ...

  10. pointer-events

    在做移动端的页面时,经常会遇到点击(touch)一个弹出的层,在上面触发点击(touch)事件,当弹出层关闭之后点击(touch)事件会穿透到下面的层,这时候如果下一层的某个元素也绑定了点击(touc ...