Kindeditor 是一套開源的在線HTML編輯器,主要用於讓用戶在網站上得到所見即所得編輯效果,咱們能夠用 KindEditor 把傳統的多行文本輸入框(textarea)替換爲可視化的富文本輸入框。javascript
快速:體積小,加載速度快
開源:開放源代碼,高水平,高品質
底層:內置自定義 DOM 類庫,精確操做 DOM
擴展:基於插件的設計,全部功能都是插件,可根據需求增減功能
風格:修改編輯器風格很是容易,只需修改一個 CSS 文件
兼容:支持大部分主流瀏覽器,好比 IE、Firefox、Safari、Chrome、Opera。css
<%@page contentType="text/html;charset=UTF-8" trimDirectiveWhitespaces="true"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script src="js/jquery.js"></script> <script type="text/javascript"> //kindeditor控件有須要 var basePath = '${pageContext.request.scheme}://${pageContext.request.serverName}:${pageContext.request.serverPort}${pageContext.request.contextPath}/'; </script> <title>測試頁面</title> <!-- 編輯器控件 --> <link rel="stylesheet" href="plugins/kindeditor/themes/default/default.css" /> <script charset="utf-8" src="plugins/kindeditor/kindeditor-min.js"></script> <script charset="utf-8" src="plugins/kindeditor/lang/zh_CN.js"></script> <script> var editor; KindEditor.ready(function(K) { editor = K.create('textarea[name="content"]', { allowFileManager : true }); editor.html("你能夠測試一下插入文件和插入圖片功能,提交後能夠在下方看見預覽!"); }); function submitForm() { $.ajax({ type: "POST", url: "ajaxForm.do",//ajsx提交表單 data: {"content":editor.html()}, success: function(data) { if(data) { $("textarea[name=content]").val(""); editor.html(""); } }, error: function() { alert("操做失敗"); } }); } </script> </head> <body style="background-color: #FFF"> <div class="main"> <div class="wraper"> <form id="form" name="form" class="registerform" action="" onsubmit="return false;" method="post"> <table width="100%" style="table-layout:fixed;padding-left: 10px;" border="0"> <tr> <td style="width:520px;"> <textarea rows="3" cols="10" name="content" style="width:520px;height:400px;visibility:hidden;"></textarea> </td> </tr> <tr> <td style="padding:10px 0 18px 0;"> <input type="button" value="提 交" id="submit" onclick="submitForm();"/> </td> </tr> </table> </form> </div> </div> </body> </html>
使用默認的kindeditor模式中,圖片上傳路徑/kindeditor/plugins/filemanager/filemanager.js中第16行左右的uploadJson和圖片管理路徑/kindeditor/plugins/filemanager/filemanager.js中第十二行fileManagerJson修改成:basePath+「/kindeditor/file_upload.do」 和basePath+「/kindeditor/file_manager_json.do」html
/** * kindeditor文件上傳控制器 * @author Rrenchuan.Qin * @date 2013-7-17 下午1:38:19 */ @Controller @RequestMapping("kindeditor") public class KindEditorController { /** * 文件上傳 * @param request * @param response * @return * @throws ServletException * @throws IOException * @throws FileUploadException */ @SuppressWarnings("rawtypes") @RequestMapping(value = "file_upload.do") //@ResponseBody public void fileUpload(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, FileUploadException { ServletContext application = request.getSession().getServletContext(); String savePath = application.getRealPath("/") + "attached/"; // 文件保存目錄URL String saveUrl = request.getContextPath() + "/attached/"; // 定義容許上傳的文件擴展名 HashMap<String, String> extMap = new HashMap<String, String>(); extMap.put("image", "gif,jpg,jpeg,png,bmp"); extMap.put("flash", "swf,flv"); extMap.put("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb"); extMap.put("file", "doc,docx,xls,xlsx,ppt,htm,html,xml,sql,txt,zip,rar,gz,bz2,pdf"); // 最大文件大小 long maxSize = 10000000; response.setContentType("text/html; charset=UTF-8"); if (!ServletFileUpload.isMultipartContent(request)) { writeMsg(response, "請選擇文件。"); return; } // 檢查目錄 File uploadDir = new File(savePath); if (!uploadDir.isDirectory()) { writeMsg(response, "上傳目錄不存在。"); return; } // 檢查目錄寫權限 if (!uploadDir.canWrite()) { writeMsg(response, "上傳目錄沒有寫權限。"); return; } String dirName = request.getParameter("dir"); if (dirName == null) { dirName = "image"; } if (!extMap.containsKey(dirName)) { writeMsg(response, "目錄名不正確。"); return; } // 建立文件夾 savePath += dirName + "/"; saveUrl += dirName + "/"; File saveDirFile = new File(savePath); if (!saveDirFile.exists()) { saveDirFile.mkdirs(); } SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd"); String ymd = sdf.format(new Date()); savePath += ymd + "/"; saveUrl += ymd + "/"; File dirFile = new File(savePath); if (!dirFile.exists()) { dirFile.mkdirs(); } FileItemFactory factory = new DiskFileItemFactory(); ServletFileUpload upload = new ServletFileUpload(factory); upload.setHeaderEncoding("UTF-8"); List items = upload.parseRequest(request); Iterator itr = items.iterator(); while (itr.hasNext()) { FileItem item = (FileItem) itr.next(); String fileName = item.getName(); if (!item.isFormField()) { // 檢查文件大小 if (item.getSize() > maxSize) { writeMsg(response, "上傳文件大小超過限制。"); return; } // 檢查擴展名 String fileExt = fileName.substring( fileName.lastIndexOf(".") + 1).toLowerCase(); if (!Arrays.<String> asList(extMap.get(dirName).split(",")) .contains(fileExt)) { writeMsg(response, "上傳文件擴展名是不容許的擴展名。\n只容許" + extMap.get(dirName) + "格式。"); return; } SimpleDateFormat df = new SimpleDateFormat("yyyyMMddHHmmss"); String newFileName = df.format(new Date()) + "_" + new Random().nextInt(1000) + "." + fileExt; try { File uploadedFile = new File(savePath, newFileName); item.write(uploadedFile); } catch (Exception e) { writeMsg(response, "上傳文件失敗。"); return; } Map<String, Object> msg = new HashMap<String, Object>(); msg.put("error", 0); msg.put("url", saveUrl + newFileName); //WebUtil.writerJson(response, msg); writeJson(response, msg); } } } /** * 輸出信息 * @param response * @param message */ private void writeMsg(HttpServletResponse response, String message) { Map<String, Object> msg = new HashMap<String, Object>(); msg.put("error", 1); msg.put("message", message); //WebUtil.writerJson(response, msg); writeJson(response, msg); } /** *輸出json 解決ie * @param response * @param msg */ private void writeJson(HttpServletResponse response, Object msg) { response.reset(); response.setCharacterEncoding("UTF-8"); response.setContentType("text/html"); PrintWriter writer = null; try { writer = response.getWriter(); writer.println(JSON.toJSONString(msg)); writer.flush(); } catch (IOException e) { e.printStackTrace(); } finally { if (writer != null) { try { writer.close(); } catch (Exception e) { e.printStackTrace(); } } } } /** * 文件管理 * @param request * @param response * @throws ServletException * @throws IOException */ @SuppressWarnings({ "rawtypes", "unchecked" }) @RequestMapping(value = "file_manager_json.do") public void fileManager(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { ServletContext application = request.getSession().getServletContext(); ServletOutputStream out = response.getOutputStream(); // 根目錄路徑,能夠指定絕對路徑,好比 /var/www/attached/ String rootPath = application.getRealPath("/") + "attached/"; // 根目錄URL,能夠指定絕對路徑,好比 http://www.yoursite.com/attached/ String rootUrl = request.getContextPath() + "/attached/"; // 圖片擴展名 String[] fileTypes = new String[] { "gif", "jpg", "jpeg", "png", "bmp" }; String dirName = request.getParameter("dir"); if (dirName != null) { if (!Arrays.<String> asList( new String[] { "image", "flash", "media", "file" }) .contains(dirName)) { out.println("Invalid Directory name."); return; } rootPath += dirName + "/"; rootUrl += dirName + "/"; File saveDirFile = new File(rootPath); if (!saveDirFile.exists()) { saveDirFile.mkdirs(); } } // 根據path參數,設置各路徑和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) { out.println("Access is not allowed."); return; } // 最後一個字符不是/ if (!"".equals(path) && !path.endsWith("/")) { out.println("Parameter is not valid."); return; } // 目錄不存在或不是目錄 File currentPathFile = new File(currentPath); if (!currentPathFile.isDirectory()) { 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()); } Map<String, Object> msg = new HashMap<String, Object>(); msg.put("moveup_dir_path", moveupDirPath); msg.put("current_dir_path", currentDirPath); msg.put("current_url", currentUrl); msg.put("total_count", fileList.size()); msg.put("file_list", fileList); response.setContentType("application/json; charset=UTF-8"); String msgStr = ""; msgStr = JSON.toJSONString(msg); out.println(msgStr); } @SuppressWarnings("rawtypes") 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")); } } } @SuppressWarnings("rawtypes") 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; } } } } @SuppressWarnings("rawtypes") 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")); } } } }