欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Bootstrap的fileinput插件實現(xiàn)多文件上傳的方法

 更新時間:2016年09月05日 11:51:16   作者:小寒丶java  
這篇文章主要介紹了Bootstrap的fileinput插件實現(xiàn)多文件上傳的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

*1.bootstrap-fileinput 插件git下載地址

https://github.com/kartik-v/bootstrap-fileinput.git

2.解決使用bootstrap-fileinput得到返回值

上傳圖片

$("#file-0a").fileinput({
uploadUrl : "/upload_img",//上傳圖片的url
allowedFileExtensions : [ 'jpg', 'png', 'gif' ],
overwriteInitial : false,
maxFileSize : 1000,//上傳文件最大的尺寸
maxFilesNum : 1,//上傳最大的文件數(shù)量
initialCaption: "請上傳商家logo",//文本框初始話value
//allowedFileTypes: ['image', 'video', 'flash'],
slugCallback : function(filename) {
return filename.replace('(', '_').replace(']', '_');
}
});

注意上傳圖片事件完之后,得到返回值寫法

$('#file-0a').on('fileuploaded', function(event, data, previewId, index) {
var form = data.form, files = data.files, extra = data.extra,
response = data.response, reader = data.reader;
console.log(response);//打印出返回的json
console.log(response.paths);//打印出路徑
});

jsp頁面

<input id="file-0a" class="file" type="file" multiple
data-min-file-count="1" name="upload_logo">

其中data-min-file-count=”1”是指文件上傳最低數(shù)量

3.服務(wù)端代碼

采用了spring自帶插件上傳,框架為Springmvc

Bean

import java.util.List;
public class Picture {
private List<String> paths;
public List<String> getPaths()
{
return paths;
}
public void setPaths(List<String> paths)
{
this.paths = paths;
} 
}

Controller

@ResponseBody
@RequestMapping(value="upload_img",method=RequestMethod.POST)
public Picture uploadImage(@RequestParam MultipartFile[] upload_logo) throws IOException{
log.info("上傳圖片");
Picture pic = new Picture();
List<String> paths = new ArrayList<String>();
String dir = UploadUtil.getFolder();
for(MultipartFile myfile : upload_logo){ 
if(myfile.isEmpty()){ 
log.info("文件未上傳"); 
}else{ 
log.info("文件長度: " + myfile.getSize()); 
log.info("文件類型: " + myfile.getContentType()); 
log.info("文件名稱: " + myfile.getName()); 
log.info("文件原名: " + myfile.getOriginalFilename()); 
log.info("========================================");
//上傳文件 返回路徑
String path = UploadUtil.writeFile(myfile.getOriginalFilename(), dir, myfile.getInputStream());
log.info("文件路徑:"+path);
paths.add(path);
} 
} 
pic.setPaths(paths);
return pic;
}

uploadUtil

private static final Logger log = LoggerFactory.getLogger(UploadUtil.class);
private UploadUtil() {
}
private static SimpleDateFormat fullSdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
private static SimpleDateFormat folder = new SimpleDateFormat(
"yyyy" + File.separator + "MM" + File.separator + "dd");
/**
* 返回yyyy File.separator MM File.separator dd格式的字符串
* 
* @return
*/
public static String getFolder() {
return folder.format(new Date());
}
/**
* 文件上傳
* 
* @param srcName
* 原文件名
* @param dirName
* 目錄名
* @param input
* 要保存的輸入流
* @return 返回要保存到數(shù)據(jù)庫中的路徑
*/
public static String writeFile(String srcName, String dirName, InputStream input) throws IOException {
log.info(srcName);
// 取出上傳的目錄,此目錄是tomcat的server.xml中配置的虛擬目錄
String uploadDir = ContextUtil.getSysProp("upload_dir");//設(shè)置你上傳路徑
// 取出虛擬目錄的訪問路徑
String virtualDir = ContextUtil.getSysProp("virtual_dir");//設(shè)置你虛擬目錄訪問路徑
// 重命名文件
if (null != srcName) {
srcName = srcName.substring(srcName.indexOf("."));
} else {
srcName = ".jpg";
}
String filename = "";
// 得到要上傳的文件路徑
filename = uploadDir + File.separator + dirName + File.separator + fullSdf.format(new Date()) + srcName;
// 得到將要保存到數(shù)據(jù)中的路徑
String savePath = filename.replace(uploadDir, "");
savePath = virtualDir + savePath.replace("\\", "/");
File file = new File(filename);
if (!file.getParentFile().exists()) {
file.getParentFile().mkdirs();
}
FileOutputStream fos = new FileOutputStream(file);
// 一次30kb
byte[] readBuff = new byte[1024 * 30];
int count = -1;
while ((count = input.read(readBuff, 0, readBuff.length)) != -1) {
fos.write(readBuff, 0, count);
}
fos.flush();
fos.close();
input.close();
return savePath;
}

4.解決上傳時候遇到的一些問題

如遇見點擊上傳之后,進度條顯示為100%,jsp頁面顯示[Object,obejct],那么注意你后臺返回的是否為json對象。

以上所述是小編給大家介紹的Bootstrap的fileinput插件實現(xiàn)多文件上傳的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 小程序?qū)崿F(xiàn)留言板

    小程序?qū)崿F(xiàn)留言板

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)留言板,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 利用js實現(xiàn)可進行時間和工作調(diào)度的任務(wù)管理器

    利用js實現(xiàn)可進行時間和工作調(diào)度的任務(wù)管理器

    這篇文章主要為大家詳細介紹了如何利用js實現(xiàn)一個可進行時間和工作調(diào)度的任務(wù)管理器,文中的示例代碼簡潔易懂,有需要的小伙伴可以參考一下
    2023-10-10
  • JavaScript實現(xiàn)shuffle數(shù)組洗牌操作示例

    JavaScript實現(xiàn)shuffle數(shù)組洗牌操作示例

    這篇文章主要介紹了JavaScript實現(xiàn)shuffle數(shù)組洗牌操作,結(jié)合實例形式分析了javascript數(shù)組的定義、構(gòu)造、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01
  • RxJS中四種Subject的用法和區(qū)別

    RxJS中四種Subject的用法和區(qū)別

    RxJS中有四種不同類型的Subject,它們分別是Subject、BehaviorSubject、ReplaySubject和AsyncSubject,本文將介紹這四種Subject的用法、區(qū)別以及適用的應(yīng)用場景,并提供代碼示例,需要的朋友可以參考下
    2023-07-07
  • 跟我學習javascript的prototype,getPrototypeOf和__proto__

    跟我學習javascript的prototype,getPrototypeOf和__proto__

    跟我學習javascript的prototype,getPrototypeOf和__proto__,深入學習了三個用來訪問prototype的方法,感興趣的小伙伴們可以參考一下
    2015-11-11
  • uniapp實現(xiàn)滑動評分效果

    uniapp實現(xiàn)滑動評分效果

    這篇文章主要為大家詳細介紹了uniapp實現(xiàn)滑動評分效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 如何制作浮動廣告 JavaScript制作浮動廣告代碼

    如何制作浮動廣告 JavaScript制作浮動廣告代碼

    如果有一定的JavaScript基礎(chǔ),制作浮動廣告還是比較容易的,利用閑暇時間簡單制作了一個,感興趣的朋友可以參考下哦
    2012-12-12
  • es6 javascript對象Object.values() , Object.entries()示例詳解

    es6 javascript對象Object.values() , Object.entr

    這篇文章主要介紹了es6 javascript對象Object.values() , Object.entries()的示例代碼,本文結(jié)合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • js繪制圓形和矩形的方法

    js繪制圓形和矩形的方法

    這篇文章主要介紹了js繪制圓形和矩形的方法,涉及javascript鼠標事件及頁面元素樣式的相關(guān)操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • 微信小程序中換行空格(多個空格)寫法詳解

    微信小程序中換行空格(多個空格)寫法詳解

    這篇文章主要介紹了微信小程序中換行空格(多個空格)寫法詳解,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-07-07

最新評論