jQuery利用FormData上傳文件實(shí)現(xiàn)批量上傳
在項(xiàng)目中涉及題庫(kù)的批量上傳功能,在此利用formdata進(jìn)行文件上傳,后臺(tái)讀取,進(jìn)行批量插入。同時(shí)還需要帶入teacherId和courseId兩個(gè)參數(shù),所以將文件和兩個(gè)參數(shù)append到formdata中,傳到后臺(tái)。
JQuery 函數(shù)的提交按鈕執(zhí)行的函數(shù)如下:
<script type="text/javascript"> //批量上傳題庫(kù) function fileSubmit() { var questionFile = new FormData(); var fileObj = document.getElementById("questionFile").files[0]; // js 獲取文件對(duì)象,questionFile為文件選擇框的Id questionFile.append("file", fileObj); var teacherId=localStorage.getItem("teacherId"); questionFile.append("teacherId",teacherId); var courseId=localStorage.getItem("courseId"); questionFile.append("courseId",courseId); $.ajax({ async: false, type:"post", url:"/questions/batchUpload", data:questionFile, processData : false, //必須false才會(huì)避開(kāi)jQuery對(duì) formdata 的默認(rèn)處理 contentType : false, //必須false才會(huì)自動(dòng)加上正確的Content-Type success:function (data) { layer.msg("上傳成功"); example.ajax.reload(); } }); } </script>
需要注意的是以下兩點(diǎn):
- jQuery 的 ajax 中processData設(shè)置為false (表示不需要對(duì)數(shù)據(jù)做處理)
- jQuery 的 ajax 中contentType設(shè)置為false (因?yàn)榍懊嬉呀?jīng)聲明了是‘FormData對(duì)象')
Controller 中的方法如下:
@ApiOperation(value = "批量上傳題庫(kù)") @RequestMapping(value = "/batchUpload",method = RequestMethod.POST) public void batchUploadQuestions(HttpServletRequest request) throws Exception{ Collection<Part> files = request.getParts(); questionsService.batchUploadQuestions(files); }
Service中的方法如下:
//題庫(kù)的批量上傳 @Override public void batchUploadQuestions(Collection<Part> files) throws Exception { Iterator<Part> it = files.iterator(); Part file = it.next(); Workbook workbook = null; if (file.getSubmittedFileName().endsWith("xlsx")) { workbook = new XSSFWorkbook(file.getInputStream()); } else if (file.getSubmittedFileName().endsWith("xls")) { workbook = new HSSFWorkbook(file.getInputStream()); } Cell cell = null; List<Questions> questionsList = new ArrayList<>(); //判斷Excel中有幾張表,目前設(shè)定為一張表 Sheet sheet = workbook.getSheetAt(0);//獲取sheet表 for (int rowIndex = 2; rowIndex <= sheet.getLastRowNum(); rowIndex++) { //獲取到一行 Row row = sheet.getRow(rowIndex); if (row == null) { continue; } Questions questions = new Questions(); List<String> strList = new ArrayList<>(); for (int i = 1; i < row.getLastCellNum(); i++) { //獲取到一列,第一列為序號(hào)不需要存入數(shù)據(jù)庫(kù),所以從1開(kāi)始讀 cell = row.getCell(i); String value = ""; switch (cell.getCellTypeEnum()) { case _NONE: break; case STRING: value = cell.getStringCellValue(); break; case NUMERIC: Pattern points_ptrn = Pattern.compile("0.0+_*[^/s]+"); if (DateUtil.isCellDateFormatted(cell)) {//日期 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); value = sdf.format(DateUtil.getJavaDate(cell.getNumericCellValue())); } else if ("@".equals(cell.getCellStyle().getDataFormatString()) || "General".equals(cell.getCellStyle().getDataFormatString()) || "0_".equals(cell.getCellStyle().getDataFormatString())) { //文本 or 常規(guī) or 整型數(shù)值 DecimalFormat df = new DecimalFormat("0"); value = df.format(cell.getNumericCellValue()); } else if (points_ptrn.matcher(cell.getCellStyle().getDataFormatString()).matches()) {//正則匹配小數(shù)類型 value = String.valueOf(cell.getNumericCellValue());//直接顯示 } break; default: value = cell.toString(); } if ((i == 2 || i == 3) && value.equals("")) {//此處設(shè)計(jì)不需要讀入的單元格 strList.clear(); break; } strList.add(value); } if (strList.size() == 9) { //對(duì)應(yīng)數(shù)據(jù)庫(kù)屬性進(jìn)行存儲(chǔ) questions.setChapter(strList.get(0)); questions.setSection(strList.get(1)); questions.setType(strList.get(2)); questions.setQuestion(strList.get(3)); questions.setAnswerA(strList.get(4)); questions.setAnswerB(strList.get(5)); questions.setAnswerC(strList.get(6)); questions.setAnswerD(strList.get(7)); questions.setAnswerTrue(strList.get(8)); questionsList.add(questions); } } //將前臺(tái)存進(jìn)的teacherId也當(dāng)做文件進(jìn)行讀取 Part file1 = it.next(); InputStream inputStream = file1.getInputStream(); BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream)); String line = null; String teacherId = ""; while ((line = bufferedReader.readLine()) != null) { teacherId = line; } //將前臺(tái)傳入的courseId當(dāng)做文件讀取 Part file2 = it.next(); InputStream inputStream1 = file2.getInputStream(); BufferedReader bufferedReader1 = new BufferedReader(new InputStreamReader(inputStream1)); String line1 = null; String courseId = ""; while ((line1 = bufferedReader1.readLine()) != null) { courseId = line1; } batchSaveQuestionList(teacherId, courseId, questionsList); } //SQL 語(yǔ)句拼接后傳入DAO層進(jìn)行數(shù)據(jù)插入 public void batchSaveQuestionList(String teacherId,String courseId,List<Questions> questionsList){ String sql = "replace into questions(questionId,courseId,teacherId,chapter,section,type,question,answerA,answerB,answerC,answerD,answerTrue) values"; for(int i = 0;i<questionsList.size();i++){ String questionId = String.valueOf(System.currentTimeMillis())+i; if(i==0){ sql+="('"+questionId+"','"+courseId+"','"+teacherId+"','"+questionsList.get(i).getChapter()+"','"+questionsList.get(i).getSection() + "','"+questionsList.get(i).getType()+"','"+questionsList.get(i).getQuestion()+ "','"+ questionsList.get(i).getAnswerA() +"','"+questionsList.get(i).getAnswerB()+"','"+questionsList.get(i).getAnswerC()+"','"+questionsList.get(i).getAnswerD() +"','"+questionsList.get(i).getAnswerTrue()+"')"; }else{ sql+=",('"+questionId+"','"+courseId+"','"+teacherId+"','"+questionsList.get(i).getChapter()+"','"+questionsList.get(i).getSection() + "','"+questionsList.get(i).getType()+"','"+questionsList.get(i).getQuestion()+ "','"+ questionsList.get(i).getAnswerA() +"','"+questionsList.get(i).getAnswerB()+"','"+questionsList.get(i).getAnswerC()+"','"+questionsList.get(i).getAnswerD() +"','"+questionsList.get(i).getAnswerTrue()+"')"; } } questionsDao.batchSaveQuestionList(sql); }
DAO層的數(shù)據(jù)插入語(yǔ)句:
@Insert("${sql}") void batchSaveQuestionList(@Param("sql") String sql);
自此即可實(shí)現(xiàn)批量上傳,需要注意的是,這里定義的文件類型為Part類型。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家,關(guān)注腳本之家公眾號(hào)的更多精彩內(nèi)容。
相關(guān)文章
jQuery實(shí)現(xiàn)字體顏色漸變效果的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)字體顏色漸變效果的方法,結(jié)合實(shí)例形式分析了jQuery動(dòng)態(tài)設(shè)置元素屬性實(shí)現(xiàn)字體顏色漸變效果的相關(guān)操作技巧,需要的朋友可以參考下2017-03-03jQuery控制文本框只能輸入數(shù)字和字母及使用方法
這篇文章主要介紹了jQuery控制文本框只能輸入數(shù)字和字母及使用方法的相關(guān)資料,非常不錯(cuò)而且實(shí)用性也很高,需要的朋友可以參考下2016-05-05jQuery實(shí)現(xiàn)簡(jiǎn)單的抽獎(jiǎng)游戲
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)簡(jiǎn)單的抽獎(jiǎng)游戲,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05jQuery實(shí)現(xiàn)動(dòng)畫效果circle實(shí)例
這篇文章主要介紹了jQuery實(shí)現(xiàn)動(dòng)畫效果circle的方法,涉及jquery鼠標(biāo)事件及頁(yè)面動(dòng)畫操作相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08JQuery的Validation插件中Remote驗(yàn)證的中文問(wèn)題
前段時(shí)間,再次出現(xiàn)AJAX中文編碼問(wèn)題,導(dǎo)致會(huì)員名重復(fù)檢測(cè)失敗,不過(guò)這次出現(xiàn)問(wèn)題的是Validation插件的remote驗(yàn)證。2010-07-07jQuery使用toggleClass方法動(dòng)態(tài)添加刪除Class樣式的方法
這篇文章主要介紹了jQuery使用toggleClass方法動(dòng)態(tài)添加刪除Class樣式的方法,實(shí)例分析了jQuery中toggleClass方法操作class樣式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03