文件上传跨域解决方案-jQuery-File-Upload
GIT 下载地址
https://github.com/blueimp/jQuery-File-Upload
亲测HTTPS HTTP跨域无压力
不用自带的DEMO
用下面的DEMO
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>jQuery File Upload Example</title>
</head>
<style>
.bar {
height: 18px;
background: green;
}
.content{
width: 100%;text-align: center;margin-top: 70px;
}
#progress{
border-radius:6px;width: 300px;background: red;
margin: 10px auto;
}
</style>
<body> <div class="content">
<input id="fileupload" type="file" name="upfile" ">
<div id="progress">
<div class="bar" style="width: 0%;"></div>
</div>
<img id="uploadimg" src="__PUBLIC__/images/bg.jpg" width="400px" height="408px"/>
</div> <script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
<script src="js/vendor/jquery.ui.widget.js"></script>
<script src="js/jquery.iframe-transport.js"></script>
<script src="js/jquery.fileupload.js"></script>
<script> $('#fileupload').fileupload({
url: "",
type:"POST",
dataType:"json",
autoUpload : true,
acceptFileTypes: /(\.|\/)(jpe?g|png)$/i,
        //跨域
        	        forceIframeTransport: true,
            formData: {
                action:"UploadVMKImagePath",
                param:JSON.stringify({
                    projectId:12343,
                    fileType:"任务日志图片"
                })
            },
            done: function (e, data) {
                console.log(e);
                console.log(data);//data里面包含了服务端返回的字段
            },
            fail:function(e,data){
                console.log("上传失败:"+data.errorThrown);
            },
             progressall: function (e, data) {
                        var progress = parseInt(data.loaded / data.total * 100);
                        $('#progress .bar').css(
                            'width',
                            progress + '%'
                        );
                    },
        });
</script>
</body>
</html>
中间遇到的问题是,一旦采用了跨域 就会使用FROM包含 iframe的方式上传,所以在done函数里是无法直接拿到服务器的返回值的。
这个插件定义的是这样 如果采用了iframe方式,必须要设置一个CALL参数,当服务器接受完你的上传数据 回CALL你设置的页面
redirectParamName:"callUrl",
redirect:"http://"+window.location.host+"/app/callupload.html?",//回调页面
很显然服务端要接受和处理你这个callurl,不过这次的项目中,目标上传服务器的处理完上传后,是直接把数据写到页面的。而不是去CALL什么地址。。
没法。。只有从其他地方下手了。
通过调试发现
既然iframe,上传完成后服务端的返回内容一定iframe里面的。
jquery.iframe-transport.js
在这个文件里的下面代码中可以记录下服务器返回的结果
 window.setTimeout(function () {
                                    // Removing the form in a setTimeout call
                                    // allows Chrome's developer tools to display
                                    // the response result
                                    console.log("【upload-iframe】");
                                        console.log(iframe);
                                    //form.remove();
                                }, );
iframe 这个参数在jquery.iframe-transport.js中就定义好了,输出看看就知道了
文件上传跨域解决方案-jQuery-File-Upload的更多相关文章
- .net文件上传,客户端用jquery file upload
		<%@ WebHandler Language="C#" Class="Handler" %> using System; using System ... 
- 文件上传报错:Unknown: file created in the system's temporary directory
		nginx+php下文件上传成功,但会有错误提示如下: <b>Notice</b>: Unknown: file created in the system's tempor ... 
- springmvc文件上传 参数为MultipartFile 转换为File
		package cn.com.mcd.controller;import java.io.File;import java.io.IOException;import java.io.Serializ ... 
- SpringBoot文件上传异常之提示The temporary upload location xxx is not valid
		原文: 一灰灰Blog之Spring系列教程文件上传异常原理分析 SpringBoot搭建的应用,一直工作得好好的,突然发现上传文件失败,提示org.springframework.web.multi ... 
- UEditor单图上传跨域问题解决方案
		UEditor UEditor是百度团队提供的富文本编辑器 git地址为:https://github.com/fex-team/ueditor 在最近的项目中使用了该插件作为项目的富文本编辑器 由于 ... 
- kindedit,uedit 上传跨域返回
		1.kindedit 跨域上传图片的时候,a.com 上传到b.com接收图片服务器,然后返回图片地址. 2.一般如果不做任何处理是获取不到返回的信息的.原因是跨域了 3.所以一般在上传成功后,在跳转 ... 
- Win2008或IIS7的文件上传大小限制解决方案
		默认情况下,IIS7的上传限制为200K.当上传文件小于30M时,可以通过如下方法设置:在iis7中找到asp设置,在“asp”的“限制属性”中最后一行“最大请求主体限制”,修改该值为你所想要的,如2 ... 
- 在系统下文件上传报错:The temporary upload location [/tmp/tomcat.xxx/work/Tomcat/localhost/ROOT] is not valid
		线上的系统中长时间不访问时不能上传文件了,出现如下错误: 2019-03-11 23:37:42.741 ERROR 66505 --- [nio-8081-exec-3] o.a.c.c.C.[.[ ... 
- springboot 文件上传 java.io.IOException: The temporary upload location [/tmp/xx] is not valid
		转自:http://meia.fun/article/1541578061808 首先分析下出现问题的原因:linux 下的 /tmp 目录,是用来存储由各种程序创建的临时文件的地方.一些配置,导致系 ... 
随机推荐
- [Python] Codecombat 攻略 Sarven 沙漠 (1-43关)截止至36关
			首页:https://cn.codecombat.com/play语言:Python 第二界面:Sarven沙漠(43关)时间:4-11小时内容:算术运算,计数器,while循环,break(跳出循环 ... 
- rugarch包与R语言中的garch族模型
			来源:http://www.dataguru.cn/article-794-1.html rugarch包是R中用来拟合和检验garch模型的一个包.该包最早在http://rgarch.r-forg ... 
- element 中表单验证的解析。
			https://blog.csdn.net/qq_24504591/article/details/88048894 https://segmentfault.com/a/11900000125513 ... 
- Mongo Restore
			#!/bin/sh HOST_IP=`/sbin/ifconfig | sed -n 's/.*inet addr:\([0-9.]\+\)\s.*/\1/p' | head -n1` echo &q ... 
- ACM-ICPC 2018 青岛赛区现场赛 D. Magic Multiplication && ZOJ 4061 (思维+构造)
			题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4061 题意:定义一个长度为 n 的序列 a1,a2,..,an ... 
- Jquery的toggle()与trigger()方法
			我一直分不清楚toggle()与trigger()两个各自的作用,所以今天抽时间记录一些,以加深印象. 1.toggle() 定义和用法: toggle() 方法切换元素的可见状态.如果被选元素可见, ... 
- Guardian of Decency POJ - 2771 【二分匹配,最大独立集】
			Problem DescriptionFrank N. Stein is a very conservative high-school teacher. He wants to take some ... 
- BZOJ 2169 连边 DP
			思路:DP 提交:\(1\)次(课上刚讲过) 题解: 如果不管重边的话,我们设\(f[i][j]\)表示连了\(i\)条边,\(j\)个点的度数是奇数的方案数,那么显然我们可以分三种状态转移: \(f ... 
- P1169 [ZJOI2007]棋盘制作 悬线法or单调栈
			思路:悬线法\(or\)单调栈 提交:2次 错因:正方形面积取错了\(QwQ\) 题解: 悬线法 讲解:王知昆\(dalao\)的\(PPT\) 详见代码: #include<cstdio> ... 
- 浏览器事件环(EventLoop)
			1. 基础知识 1. js语言特点 1. js语言是单线程语言,主线程是单线程.如UI渲染,脚本加载是主线程任务. 2. js语言采用事件循环(EventLoop)机制. 2. 同步任务: 不被引擎挂 ... 
