官网下载文件http://plugins.krajee.com/file-input/demo
bootstrap fileinput 是基于bootstrap基础上的上传插件,so必要的bootstrap文件是要引用的...
1.引用js和css文件
fileinput.css
fileinput.min.js
中文字体
2.初始化fileinput
前台
jsp:
如果已经存在,换个名字即可,如class="file1"class
js:
step1:上传部分,可携带额外参数
$("#fileInput").fileinput('destroy'); // 直接销毁
$("#fileInput").fileinput({
language: 'zh', //设置语言
uploadUrl: GLOBAL.URL+'project/saveFile.do', //上传的地址 http;//localhost:8080/project/saveFile.do
showUpload: false, //是否显示上传按钮
showCaption: false,//是否显示标题
previewFileIcon: "",
maxFileCount: 6, //表示允许同时上传的最大文件个数
fileActionSettings:{showUpload: false}, // 控制上传按钮是否显示
uploadExtraData: function(previewId, index) { //额外参数
var obj = {};
obj.id = fodderType(); // 这里回调方法
return obj;
},
preferIconicPreview: true, // 开启用图标替换预览效果
previewFileIconSettings: { // configure your icon file extensions
'doc': '',
'xls': '',
'ppt': '',
'pdf': '',
'txt': '',
'zip': '',
'htm': '',
'mov': '',
'mp3': ''
},
previewFileExtSettings: {
'doc': function(ext) {
return ext.match(/(doc|docx)$/i);
},
'xls': function(ext) {
return ext.match(/(xls|xlsx)$/i);
},
'ppt': function(ext) {
return ext.match(/(ppt|pptx)$/i);
},
'zip': function(ext) {
return ext.match(/(zip|rar|tar|gzip|gz|7z)$/i);
},
'htm': function(ext) {
return ext.match(/(htm|html)$/i);
},
'mov': function(ext) {
return ext.match(/(avi|mpg|mkv|mov|mp4|3gp|webm|wmv)$/i);
},
'mp3': function(ext) {
return ext.match(/(mp3|wav)$/i);
},
'txt': function(ext) {
return ext.match(/(txt|ini|csv|java|php|js|css)$/i);
}
},
layoutTemplates:{ // 预览图片按钮控制,这里屏蔽预览按钮
actionZoom:''
}
});
fodderType = function() {
return $("#debugId").val();
};
step2:单独调用上传
$("#fileInput").fileinput("upload");
step3:控件回显重新初始化
// 假设后台信息已经查询完毕!假设为data!!
$("#fileInput").fileinput('destroy');
$("#fileInput").fileinput({
language: 'zh', //设置语言
uploadUrl: GLOBAL.URL+'project/saveFile.do?id='+bugId, //上传的地址
showUpload: false, //是否显示上传按钮
showCaption: false,//是否显示标题
maxFileCount: 6, //表示允许同时上传的最大文件个数
fileActionSettings:{showUpload: false},//是否显示上文件上的上传按钮
overwriteInitial: false,
allowedPreviewTypes: ['image'],
/*
!这里是预览的数据格式
initialPreview: [
// IMAGE RAW MARKUP
'http://localhost:8080/amp/base/imgs/app-default.jpg',
// IMAGE RAW MARKUP
'http://localhost:8080/amp/base/imgs/app-default.jpg',
// TEXT RAW MARKUP
'123asd啊实打实',
'http://localhost:8080/amp/base/imgs/123.docx'
],*/
initialPreview : data.initialPreview,
initialPreviewAsData: true, // allows you to set a raw markup
initialPreviewFileType: 'image', // image is the default and can be overridden in config below
initialPreviewDownloadUrl: GLOBAL.URL+'project/downFile.do?image={key}',
/*
!这里是回显的数据格式,后台查询后,按照格式展示即可,url是删除访问地址,key是删除的id
initialPreviewConfig: [
{type: "image", caption: "Image-1.jpg", size: 847000, url: "/amp/project/delFile.do", key: 1},
{type: "image", caption: "Image-2.jpg", size: 817000, url: "/amp/project/delFile.do", key: '1519713821098wwp4h8v'}, // set as raw markup
{type: "text", size: 1430, caption: "LoremIpsum.txt", url: "/amp/project/delFile.do", key: 3},
{type: "office", size: 102400, caption: "123.docx", url: "/amp/project/delFile.do", key: '1519788281200pwxfx87'}
],*/
initialPreviewConfig : data.initialPreviewConfig,
preferIconicPreview: true, // this will force thumbnails to display icons for following file extensions
previewFileIconSettings: { // configure your icon file extensions
'doc': '',
'xls': '',
'ppt': '',
'pdf': '',
'txt': '',
'zip': '',
'htm': '',
'mov': '',
'mp3': ''
},
previewFileExtSettings: { // configure the logic for determining icon file extensions
'doc': function(ext) {
return ext.match(/(doc|docx)$/i);
},
'xls': function(ext) {
return ext.match(/(xls|xlsx)$/i);
},
'ppt': function(ext) {
return ext.match(/(ppt|pptx)$/i);
},
'zip': function(ext) {
return ext.match(/(zip|rar|tar|gzip|gz|7z)$/i);
},
'htm': function(ext) {
return ext.match(/(htm|html)$/i);
},
'mov': function(ext) {
return ext.match(/(avi|mpg|mkv|mov|mp4|3gp|webm|wmv)$/i);
},
'mp3': function(ext) {
return ext.match(/(mp3|wav)$/i);
},
'txt': function(ext) {
return ext.match(/(txt|ini|csv|java|php|js|css)$/i);
}
},
layoutTemplates:{
actionZoom:''
},
uploadExtraData: {
img_key: "1000",
img_keywords: "happy, nature"
}
});
后台上传:
@RequestMapping("/saveFile")
@ResponseBody
public String saveFile(@RequestParam(value="files") MultipartFile file,
HttpServletRequest request,HttpServletResponse response){
OutputStream os = null;
InputStream is = null;
boolean returnBoolean = false;
String bug_id = request.getParameter("id"); // 传过来的额外参数
try {
String path = "E:\\WORK\\TOMCAT\\apache-tomcat-8.5.24-amp\\wtpwebapps\\amp";
SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd");
String currentDate = df.format(System.currentTimeMillis());
String pathTemp = path + File.separator + currentDate + File.separator + bug_id;
File fileTemp = new File(pathTemp);
if(!fileTemp.exists()) {
fileTemp.mkdirs();
}
String fullFilePath = pathTemp + File.separator + file.getOriginalFilename();
File fullFile = new File(fullFilePath);
os = new FileOutputStream(fullFile);
is =file.getInputStream();
byte buf[] = new byte[1024];//可以修改 1024 以提高读取速度
int length = 0;
while( (length = is.read(buf)) > 0 ){
os.write(buf, 0, length);
}
returnBoolean = true;
} catch (Exception e) {
e.printStackTrace();
} finally {
if(is !=null) {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
if(os !=null) {
try {
os.flush();
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return JSONObject.fromObject("{\"success\":"+ returnBoolean +"}").toString();
}