说明: 其中onchange()为我业务需要, 上传完成后自动执行一个添加事件。 此方法可以去掉。
2. 获取初始化数据方法:
获取原有
文件
$(function(){
$.ajax({
type : "post",url : "/eim/project/testFileUpload.do",dataType : "json",success : function(data) {
layer.msg('操作成功!');
showPhotos(data);
},error: function(XMLHttpRequest,textStatus,errorThrown) {
layer.msg('操作失败!');
}
});
});
说明:此处我返回是一个 对象数组:List,可以理解为获取一个班中所有的学生,展示头像
3.初始化bootstrap-fileinput 组件:
后台返回json字符串转换为json对象
var reData = eval(djson);
// 预览
图片json数据组
var preList = new Array();
for ( var i = 0; i < reData.length; i++) {
var array_element = reData[i];
// 此处指针对.txt判断,其余自行添加
if(array_element.fileIdFile.name.indexOf("txt")>0){
// 非
图片类型的展示
preList[i]= "@H_
502_34@
"
}else{
//
图片类型
preList[i]= "
图片json数据组 对应的config数据
var preConfigList = new Array();
for ( var i = 0; i < reData.length; i++) {
var array_element = reData[i];
var tjson = {caption: array_element.fileIdFile.fileName,// 展示的
文件名
width: '120px',url: '/eim/project/deleteFile.do',//
删除url
key: array_element.id,//
删除是Ajax向
后台传递的参数
extra: {id: 100}
};
preConfigList[i] = tjson;
}
// 具体参数自行
查询
$('#test
logo').fileinput({
uploadUrl: '/eim/upload/uploadFile.do',uploadAsync:true,showCaption: true,showUpload: true,//是否
显示上传按钮
showRemove: false,//是否
显示删除按钮
showCaption: true,//是否
显示输入框
showPreview:true,showCancel:true,dropZoneEnabled: false,maxFileCount: 10,initialPreviewShowDelete:true,msgFilesTooMany: "选择
上传的
文件数量 超过允许的最大数值!",initialPreview: previewJson,previewFileIcon: '
',allowedPreviewTypes: ['image'],previewFileIconSettings: {
'docx': '','xlsx': '','pptx': '','pdf': '','zip': '','sql': '',},initialPreviewConfig: preConfigList
}).off('filepreupload').on('filepreupload',function() {
// alert(data.url);
}).on("fileuploaded",function(event,outData) {
//文件上传成功后返回的数据, 此处我只保存返回文件的id
var result = outData.response.id;
// 对应的input 赋值
$('#htestlogo').val(result).change();
});
}
文件下载
*
* @param savePath
* 保存目录
* @param name
*
文件原名
* @param file
* 保存时的
名称 包含后缀
* @param request
* @param response
* @return
*/
public static String down(String savePath,String name,String fileName,HttpServletRequest request,HttpServletResponse response) {
try {
String path = savePath + "/" + name;
File file = new File(path);
if (!file.exists()) {
// 不存在
request.setAttribute("name",fileName);
return "download_error";// 返回下载
文件不存在
}
response.setContentType("application/octet-stream");
// 根据不同浏览器 设置response的Header
String userAgent = request.getHeader("User-Agent").toLowerCase();
if (userAgent.indexOf("msie") != -1) {
// ie浏览器
// System.out.println("ie浏览器");
response.addHeader("Content-Disposition","attachment;filename=" + URLEncoder.encode(name,"utf-8"));
} else {
response.addHeader("Content-Disposition","attachment;filename=" + new String(name.getBytes("utf-8"),"ISO8859-1"));
}
response.addHeader("Content-Length","" + file.length());
// 以流的形式下载
文件
InputStream fis = new BufferedInputStream(new FileInputStream(path));
byte[] buffer = new byte[fis.available()];
fis.read(buffer);
fis.close();
//response.setContentType("image/*"); // 设置返回的
文件类型
OutputStream toClient = response.getOutputStream();
OutputStream bos = new BufferedOutputStream(toClient);
//BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(bos));
bos.write(buffer);
//bw.close();
bos.close();
toClient.close();
return null;
} catch (Exception e) {
e.printStackTrace();
//response.reset();
return "exception";// 返回异常
页面
} finally {
/* if (toClient != null) {
try {
toClient.close();
} catch (IOException e) {
e.printStackTrace();
}
}*/
}
}