springmvc+kindeditor文件上傳實(shí)例詳解
本文實(shí)例為大家分享了springmvc+kindeditor文件上傳的具體代碼,供大家參考,具體內(nèi)容如下
壓縮包里面的jar放到tomcat的lib文件夾下,kindeditor文件放工程里,不用的可以刪掉
jsp頁面
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <link rel="stylesheet" rel="external nofollow" > <script src="https://cdn.bootcss.com/jquery/2.1.1/jquery.min.js"></script> <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script> <script src="./kindeditor/kindeditor-all-min.js"></script> <script src="./kindeditor/lang/zh-CN.js"></script> <script> KindEditor .ready(function(K) { window.editor = K .create( '#editor_id', { uploadJson : 'Kindeditor/uploadFile', fileManagerJson : 'Kindeditor/fileManager', allowImageUpload : true, //多圖上傳 allowFileManager : true, //瀏覽圖片空間 filterMode : false, //HTML特殊代碼過濾 afterBlur : function() { this.sync(); }, //編輯器失去焦點(diǎn)(blur)時執(zhí)行的回調(diào)函數(shù)(將編輯器的HTML數(shù)據(jù)同步到textarea) afterUpload : function(url, data, name) { //上傳文件后執(zhí)行的回調(diào)函數(shù),必須為3個參數(shù) if (name == "image" || name == "multiimage") { //單個和批量上傳圖片時 if (K("#pic").length > 0) { //文本框存在 document .getElementById('piclist').options[document .getElementById('piclist').length] = new Option( url, url); //下拉列表框增加一條 document .getElementById('piclist').selectedIndex += 1; //選定剛新增的這一條 K("#indexpicimg") .html( "<img src='" + url + "' width='150' height='95' />"); //重置圖片展示區(qū)DIV的HTML內(nèi)容 K("#pic").val(url); //重置文本框值 } } } }); }); </script> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form class="form-horizontal" role="form" action="articleAdd" method="post" > <div class="form-group"> <label for="firstname" class="col-sm-2 control-label">標(biāo)題</label> <div class="col-sm-5"> <input type="text" class="form-control" id="title" name="title" placeholder="請輸入標(biāo)題"> </div> </div> <div class="form-group"> <label for="lastname" class="col-sm-2 control-label">類別</label> <div class="col-sm-3"> <select class="form-control" name="categoryId"> <option>1</option> <option>2</option> <option>3</option> <option>4</option> <option>5</option> </select> </div> </div> <div class="form-group"> <label for="lastname" class="col-sm-2 control-label">內(nèi)容</label> <div class=" col-sm-5"> <textarea id="editor_id" name="details" class="form-control" > <strong>HTML內(nèi)容</strong> </textarea> </div> </div> <div class="form-group"> <div class="col-sm-offset-2 col-sm-10"> <button type="submit" class="btn btn-default">保存草稿</button> </div> </div> </form> </body> </html>
KindAction.java
package com.leo.ows.action; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileOutputStream; import java.io.PrintWriter; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.Hashtable; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.UUID; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.servlet.ServletFileUpload; import org.springframework.stereotype.Controller; import org.springframework.util.FileCopyUtils; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartHttpServletRequest; import com.alibaba.fastjson.JSONObject; @Controller public class KindAction { @RequestMapping(value ="/Kindeditor/uploadFile", method = RequestMethod.POST) public void uploadFile(HttpServletRequest request, HttpServletResponse response) throws Exception { PrintWriter writer = response.getWriter(); // 文件保存目錄路徑 String savePath = request.getSession().getServletContext().getRealPath("/") + "upload/image" + File.separatorChar + File.separatorChar; String saveUrl = request.getContextPath()+ File.separatorChar + "upload/image" + File.separatorChar + File.separatorChar; // 定義允許上傳的文件擴(kuò)展名 HashMap<String, String> extMap = new HashMap<String, String>(); extMap.put("image", "gif,jpg,jpeg,png,bmp"); // 最大文件大小 long maxSize = 1000000; response.setContentType("text/html; charset=UTF-8"); if (!ServletFileUpload.isMultipartContent(request)) { writer.println(getError("請選擇文件。")); return; } File uploadDir = new File(savePath); // 判斷文件夾是否存在,如果不存在則創(chuàng)建文件夾 if (!uploadDir.exists()) { uploadDir.mkdirs(); } // 檢查目錄寫權(quán)限 if (!uploadDir.canWrite()) { writer.println(getError("上傳目錄沒有寫權(quán)限。")); return; } String dirName = request.getParameter("dir"); if (dirName == null) { dirName = "image"; } if (!extMap.containsKey(dirName)) { writer.println(getError("目錄名不正確。")); return; } MultipartHttpServletRequest mRequest = (MultipartHttpServletRequest) request; Map<String, MultipartFile> fileMap = mRequest.getFileMap(); String fileName = null; for (Iterator<Map.Entry<String, MultipartFile>> it = fileMap.entrySet().iterator(); it.hasNext();) { Map.Entry<String, MultipartFile> entry = it.next(); MultipartFile mFile = entry.getValue(); fileName = mFile.getOriginalFilename(); // 檢查文件大小 if (mFile.getSize() > maxSize) { writer.println(getError("上傳文件大小超過限制。")); return; } String fileExt = fileName.substring(fileName.lastIndexOf(".")+1); if (!Arrays.<String> asList(extMap.get(dirName).split(",")).contains(fileExt)) { writer.println(getError("上傳文件擴(kuò)展名是不允許的擴(kuò)展名。\n只允許" + extMap.get(dirName) + "格式。")); return; } UUID uuid = UUID.randomUUID(); String path = savePath + uuid.toString() +"."+ fileExt; saveUrl = saveUrl + uuid.toString() +"."+ fileExt; BufferedOutputStream outputStream = new BufferedOutputStream(new FileOutputStream(path)); FileCopyUtils.copy(mFile.getInputStream(), outputStream); JSONObject obj = new JSONObject(); obj.put("error", 0); obj.put("url", saveUrl); writer.println(obj.toString()); } } private String getError(String message) { JSONObject obj = new JSONObject(); obj.put("error", 1); obj.put("message", message); return obj.toString(); } @RequestMapping(value = "/Kindeditor/fileManager", method = RequestMethod.GET) public void fileManager(HttpServletRequest request, HttpServletResponse response) throws Exception { //根目錄路徑,可以指定絕對路徑,比如 /var/www/attached/ String rootPath = request.getSession().getServletContext().getRealPath("/")+ "upload/"; //根目錄URL,可以指定絕對路徑,比如 http://www.yoursite.com/attached/ String rootUrl = request.getContextPath() + "/upload/"; //圖片擴(kuò)展名 String[] fileTypes = new String[]{"gif", "jpg", "jpeg", "png", "bmp"}; System.out.println(rootPath); String dirName = request.getParameter("dir"); if (dirName != null) { if(!Arrays.<String>asList(new String[]{"image", "flash", "media", "file"}).contains(dirName)){ System.out.println("Invalid Directory name."); return; } rootPath += dirName + "/"; rootUrl += dirName + "/"; File saveDirFile = new File(rootPath); if (!saveDirFile.exists()) { saveDirFile.mkdirs(); } } //根據(jù)path參數(shù),設(shè)置各路徑和URL String path = request.getParameter("path") != null ? request.getParameter("path") : ""; String currentPath = rootPath + path; String currentUrl = rootUrl + path; String currentDirPath = path; String moveupDirPath = ""; if (!"".equals(path)) { String str = currentDirPath.substring(0, currentDirPath.length() - 1); moveupDirPath = str.lastIndexOf("/") >= 0 ? str.substring(0, str.lastIndexOf("/") + 1) : ""; } //排序形式,name or size or type String order = request.getParameter("order") != null ? request.getParameter("order").toLowerCase() : "name"; //不允許使用..移動到上一級目錄 if (path.indexOf("..") >= 0) { System.out.println("Access is not allowed."); return; } //最后一個字符不是/ if (!"".equals(path) && !path.endsWith("/")) { System.out.println("Parameter is not valid."); return; } //目錄不存在或不是目錄 File currentPathFile = new File(currentPath); if(!currentPathFile.isDirectory()){ System.out.println("Directory does not exist."); return; } //遍歷目錄取的文件信息 List<Hashtable> fileList = new ArrayList<Hashtable>(); if(currentPathFile.listFiles() != null) { for (File file : currentPathFile.listFiles()) { Hashtable<String, Object> hash = new Hashtable<String, Object>(); String fileName = file.getName(); if(file.isDirectory()) { hash.put("is_dir", true); hash.put("has_file", (file.listFiles() != null)); hash.put("filesize", 0L); hash.put("is_photo", false); hash.put("filetype", ""); } else if(file.isFile()){ String fileExt = fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase(); hash.put("is_dir", false); hash.put("has_file", false); hash.put("filesize", file.length()); hash.put("is_photo", Arrays.<String>asList(fileTypes).contains(fileExt)); hash.put("filetype", fileExt); } hash.put("filename", fileName); hash.put("datetime", new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(file.lastModified())); fileList.add(hash); } } if ("size".equals(order)) { Collections.sort(fileList, new SizeComparator()); } else if ("type".equals(order)) { Collections.sort(fileList, new TypeComparator()); } else { Collections.sort(fileList, new NameComparator()); } JSONObject result = new JSONObject(); result.put("moveup_dir_path", moveupDirPath); result.put("current_dir_path", currentDirPath); result.put("current_url", currentUrl); result.put("total_count", fileList.size()); result.put("file_list", fileList); response.setContentType("application/json; charset=UTF-8"); System.out.println(result.toJSONString()); PrintWriter writer=response.getWriter(); writer.println(result); } public class NameComparator implements Comparator { public int compare(Object a, Object b) { Hashtable hashA = (Hashtable)a; Hashtable hashB = (Hashtable)b; if (((Boolean)hashA.get("is_dir")) && !((Boolean)hashB.get("is_dir"))) { return -1; } else if (!((Boolean)hashA.get("is_dir")) && ((Boolean)hashB.get("is_dir"))) { return 1; } else { return ((String)hashA.get("filename")).compareTo((String)hashB.get("filename")); } } } public class SizeComparator implements Comparator { public int compare(Object a, Object b) { Hashtable hashA = (Hashtable)a; Hashtable hashB = (Hashtable)b; if (((Boolean)hashA.get("is_dir")) && !((Boolean)hashB.get("is_dir"))) { return -1; } else if (!((Boolean)hashA.get("is_dir")) && ((Boolean)hashB.get("is_dir"))) { return 1; } else { if (((Long)hashA.get("filesize")) > ((Long)hashB.get("filesize"))) { return 1; } else if (((Long)hashA.get("filesize")) < ((Long)hashB.get("filesize"))) { return -1; } else { return 0; } } } } public class TypeComparator implements Comparator { public int compare(Object a, Object b) { Hashtable hashA = (Hashtable)a; Hashtable hashB = (Hashtable)b; if (((Boolean)hashA.get("is_dir")) && !((Boolean)hashB.get("is_dir"))) { return -1; } else if (!((Boolean)hashA.get("is_dir")) && ((Boolean)hashB.get("is_dir"))) { return 1; } else { return ((String)hashA.get("filetype")).compareTo((String)hashB.get("filetype")); } } } }
效果圖
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Kotlin 基礎(chǔ)教程之?dāng)?shù)組容器
這篇文章主要介紹了Kotlin 基礎(chǔ)教程之?dāng)?shù)組容器的相關(guān)資料,需要的朋友可以參考下2017-06-06Springboot ApplicationRunner的使用解讀
這篇文章主要介紹了Springboot ApplicationRunner的使用解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05Spring Task定時任務(wù)的實(shí)現(xiàn)詳解
這篇文章主要介紹了SpringBoot定時任務(wù)功能詳細(xì)解析,這次的功能開發(fā)過程中也算是對其內(nèi)涵的進(jìn)一步了解,以后遇到定時任務(wù)的處理也更清晰,更有效率了,對SpringBoot定時任務(wù)相關(guān)知識感興趣的朋友一起看看吧2022-08-08關(guān)于微服務(wù)使用Dubbo設(shè)置的端口和server.port的區(qū)別
這篇文章主要介紹了關(guān)于微服務(wù)使用Dubbo設(shè)置的端口和server.port的區(qū)別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12Java Socket實(shí)現(xiàn)聊天室附1500行源代碼
Socket是應(yīng)用層與TCP/IP協(xié)議族通信的中間軟件抽象層,它是一組接口。本篇文章手把手帶你通過Java Socket來實(shí)現(xiàn)自己的聊天室,大家可以在過程中查缺補(bǔ)漏,溫故而知新2021-10-10看動畫學(xué)算法之Java實(shí)現(xiàn)doublyLinkedList
這篇文章主要介紹Java實(shí)現(xiàn)doublyLinkedList,LinkedList:doublyLinkedList相對比較復(fù)雜,今天就來簡單學(xué)習(xí)一下doublyLinkedList的基本操作和概,感興趣的小伙伴可以參考下面具體文章內(nèi)容2021-10-10springboot集成kafka消費(fèi)手動啟動停止操作
這篇文章主要介紹了springboot集成kafka消費(fèi)手動啟動停止操作,本文給大家介紹項(xiàng)目場景及解決分析,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09