最近项目中需要用到 因为发现很多坑 因此发出来分享一下
流程:
- 前台用户选择文件
- 前台请求上传文件的token
- 前台上传
-
将信息提交到后台保存
前台html文件
<input name="upload" id="file2" class="easyui-filebox" style="width:300px" required=true
data-options="buttonText:'选择文件',buttonAlign: 'left'">
<input type="text" name="address" id="uploadName2" hidden="true">
<input type="button" id="uploadFile2" value="开始测试上传">
<div id="progress" style="width:400px;"></div>
需要先引入 七牛的jssdk
<script type="text/javascript">
//import * as qiniu from "../../../js/js-sdk-master/src";
//import * as qiniu from "../../../js/js-sdk-master/src";
//import * as qiniu from 'qiniu-js'
$(function () {
//添加对话框,上传控件初始化
$('#file2').filebox({
buttonText: '选择文件', //按钮文本
buttonAlign: 'right', //按钮对齐
//multiple: true, //是否多文件方式
//accept: "image/gif,image/bmp,image/jpeg,image/jpg,image/png", //指定文件类型
onChange: function (e) {
alert("进入上传处理")
var url = "/file/QiniuUpToken"
var progress = "progress"
var fileBox = "uploadName2"
var filefile = "file2"
uploadFile(progress, filefile, this, fileBox, url)
}
});
/**
*
* @param progress 进度条对象
* @param filefile 需要上传的文件控件的Id
* @param file this this就完事了no why
* @param uploadNameBox 上传的文件的名字的盒子控件
* @param uploadUrl 获取token的链接
*/
function uploadFile(progress, filefile, file, uploadNameBox, getUptpkenUrl) {
var uploadNameBox = $("#" + uploadNameBox)
var progress = $("#" + progress);
var obj = $("#" + filefile);
console.log(obj)
var fileName = $("#" + filefile).filebox('getValue');
;
//上传的本地文件绝对路径
console.log(fileName)
var suffix = fileName.substring(fileName.lastIndexOf("."), fileName.length);//后缀名
var file = $(file).context.ownerDocument.activeElement.files[0] //获取上传的文件
progress.progressbar({//生成进度条组件
value: 0
});
if (file == null) {
$.messager.alert("错误提示", "请先选择文件再点击上传")
return;
}
var size = file.size > 1024 ? file.size / 1024 > 1024 ? file.size / (1024 * 1024) > 1024 ? (file.size / (1024 * 1024 * 1024)).toFixed(2) + 'GB' : (file.size
/ (1024 * 1024)).toFixed(2) + 'MB' : (file.size
/ 1024).toFixed(2) + 'KB' : (file.size).toFixed(2) + 'B'; //文件上传大小
//七牛云上传
$.ajax({
type: 'post',
url: getUptpkenUrl,
data: {"suffix": suffix},
dataType: 'json',
success: function (result) {
if (result.success == 1) {
var observer = { //设置上传过程的监听函数
next(result) { //上传中(result参数带有total字段的 object,包含loaded、total、percent三个属性)
var value = Math.ceil(result.total.percent);//查看进度[loaded:已上传大小(字节);total:本次上传总大小;percent:当前上传进度(0-100)]
console.log(value)
if (value < 100) {
progress.progressbar('setValue', value);
}
},
error(err) { //失败后
alert(err.message);
},
complete(res) { //成功后
// ?imageView2/2/h/100:展示缩略图,不加显示原图
// ?vframe/jpg/offset/0/w/480/h/360:用于获取视频截图的后缀,0:秒,w:宽,h:高
console.log(res)
progress.progressbar('setValue', 100);
$.messager.alert("提示", "上传成功!!!")
uploadNameBox.attr("value", result.domain + "/" + result.fileUrl + "?attname=" + result.fileUrl);
}
};
var putExtra = {
fname: "", //原文件名
params: {}, //用来放置自定义变量
mimeType: null //限制上传文件类型
};
var config = {
//region:qiniu.region.z2, //存储区域(z0:代表华东;z2:代表华南,不写默认自动识别)
concurrentRequestLimit: 3 //分片上传的并发请求量
};
var observable = qiniu.upload(file, result.fileUrl, result.token, putExtra, config);
var subscription = observable.subscribe(observer); // 上传开始
// 取消上传
// subscription.unsubscribe();
} else {
$.messager.alert("提示信息", "获取上传凭证失败!") //获取凭证失败
}
}, error: function () { //服务器响应失败处理函数
$.messager.alert("提示信息", "服务器繁忙,请稍后再试")
}
});
}
后端获取 uptoke 的我就不写了