KindEditor 编辑器在springboot使用

KindEditor 编辑器在springboot使用KindEditor 编辑器在 springboot 使用官网下载 kindEditor 解决视频上传问题官网下载 kindEditor1 官网地址 http kindeditor net down php2 下载后解压 将解压文件引入到项目中由于在 java 中使用 去掉不用的文件 asp asp netjsp 3 引入 js 我这里使用的是 thymeleaf 模板 4 html 页面引入 也可以在页面直接引入 js 添加文本框

KindEditor 编辑器在springboot使用

官网下载kindEditor

 1. 官网地址 : http://kindeditor.net/down.php 

在这里插入图片描述

2.下载后解压;将解压文件引入到项目中
在这里插入图片描述

由于在java中使用;去掉不用的文件 asp,asp.net jsp;
在这里插入图片描述

3.引入js,我这里使用的是thymeleaf模板在这里插入图片描述
4.html页面引入 ;也可以在页面直接引入js ; 添加文本框

 
   添加页面:  编辑页面:  

5. 初始化富文本框
在这里插入图片描述

 ```var editor; KindEditor.ready(function (K) { 
    editor = K.create('textarea[name="context"]', { 
    allowImageUpload:true, allowImageRemote: false, //是否允许浏览服务器已上传文件,默认是false allowFileManager: true, uploadJson :"/kindEditor/uploadFile", fileManagerJson: "/kindEditor/fileManagerJson", afterBlur: function(){ 
   this.sync();}, afterUpload : function(url, data, name) { 
    //上传文件后执行的回调函数,必须为3个参数 if (name == "image" || name == "multiimage") { 
    //单个和批量上传图片时 var img = new Image(); img.src = url; img.onload = function () { 
    //图片必须加载完成才能获取尺寸 } } } }); }); 

后台代码

 @Controller @RequestMapping("/kindEditor") @Slf4j public class KinUploadController extends BaseController { 
    @Autowired private UploadFilePathConfig filePathConfig; @Autowired private ServerConfig serverConfig; / * 提供KindEditor作文件上传使用 * @param request * @param response * @throws Exception */ @PostMapping("/uploadFile") public void uploadFile(HttpServletRequest request, HttpServletResponse response) throws Exception { 
    PrintWriter writer = response.getWriter(); String datePath = DateUtils.datePath(new Date()); // 文件保存目录路径 String savePath = filePathConfig.getUploadFolder()+datePath; // String savePath = Global.getUploadPath(); // String saveUrl = filePathConfig.getBaseUrl() + File.separatorChar + "static/image" + File.separatorChar; String saveUrl = serverConfig.getUrl() + File.separatorChar + "static/image/"+datePath+"/" + File.separatorChar; // 定义允许上传的文件扩展名 HashMap<String, String> extMap = new HashMap<String, String>(); extMap.put("image", "gif,jpg,jpeg,png,bmp,JPG"); extMap.put("file", "doc,docx,xls,xlsx,ppt,htm,html,txt,zip,rar,gz,bz2,pdf"); extMap.put("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb,mp4"); // 最大文件大小 // long maxSize = ; response.setContentType("text/html; charset=UTF-8"); if (!ServletFileUpload.isMultipartContent(request)) { 
    writer.println(error("请选择文件。")); return ; } File uploadDir = new File(savePath); // 判断文件夹是否存在,如果不存在则创建文件夹 if (!uploadDir.exists()) { 
    uploadDir.mkdirs(); } // 检查目录写权限 if (!uploadDir.canWrite()) { 
    writer.println(error("上传目录没有写权限。")); return ; } String dirName = request.getParameter("dir"); if (dirName == null) { 
    dirName = "image"; } if (!extMap.containsKey(dirName)) { 
    writer.println(error("目录名不正确。")); 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(error("上传文件大小超过限制。")); return ; }*/ String fileExt = fileName.substring(fileName.lastIndexOf(".") + 1); if (!Arrays.<String>asList(extMap.get(dirName).split(",")).contains(fileExt)) { 
    writer.println(error("上传文件扩展名是不允许的扩展名。\n只允许" + extMap.get(dirName) + "格式。")); return; } UUID uuid = UUID.randomUUID(); String path = savePath +"/"+ uuid.toString() + "." + fileExt; saveUrl = saveUrl + uuid.toString() + "." + fileExt; System.out.println("path=========="+path); BufferedOutputStream outputStream = new BufferedOutputStream(new FileOutputStream(path)); FileCopyUtils.copy(mFile.getInputStream(), outputStream); log.info("【提交图片】参数正确, saveUrl={}",saveUrl); JSONObject obj = new JSONObject(); obj.put("error", 0); obj.put("url", saveUrl); writer.println(obj.toString()); } } @RequestMapping("/fileManagerJson") public void fileManagerJson(HttpServletRequest request, HttpServletResponse response) throws Exception { 
    response.setContentType("application/json; charset=UTF-8"); PrintWriter out = response.getWriter(); //根目录路径,可以指定绝对路径,比如 /var/www/attached/ String rootPath = Global.getUploadPath() + "/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()); } 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); out.println(result.toJSONString()); } } 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")); } } } 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")); } } } 

解决视频上传问题

由于kinEditor中视频标签是,h5页面可能不支持,我们需要修改kindeditor-all.js文件

1-1. 打开kindeditor-all.js 在304行的地方添加 Video标签

 video: ['id', 'class', 'src', 'width', 'height', 'type', 'loop', 'autoplay', 'quality', '.width', '.height', 'align', 'controls', 'muted','controlslist'], 

在这里插入图片描述

1-2. 然后找到 _mediaEmbed(attrs)方法;大概在 955 行

function _mediaEmbed(attrs) { 
    var html = '; _each(attrs, function(key, val) { 
      html += key + '="' + val + '" '; }); html += '/>'; return html; } 替换为: function _mediaEmbed(attrs) { 
      var html = '; _each(attrs, function(key, val) { 
        html += key + '="' + val + '" '; }); html += '/>'; // 一段简单的代码 解决视频上传问题 if (attrs.type=="video/mp4"){ 
        var html = ' 
       

1-3 找到 _mediaType(src)函数; 大概在929左右

在这个方法中添加 if (/\.(mp4)(\?|$)/i.test(src)) { 
    return 'video/mp4'; } if (/\.(ogg)(\?|$)/i.test(src)) { 
    return 'video/ogg'; } if (/\.(webm)(\?|$)/i.test(src)) { 
    return 'video/webm'; } 添加后: function _mediaType(src) { 
    if (/\.(rm|rmvb)(\?|$)/i.test(src)) { 
    return 'audio/x-pn-realaudio-plugin'; } if (/\.(swf|flv)(\?|$)/i.test(src)) { 
    return 'application/x-shockwave-flash'; } if (/\.(mp4)(\?|$)/i.test(src)) { 
    return 'video/mp4'; } if (/\.(ogg)(\?|$)/i.test(src)) { 
    return 'video/ogg'; } if (/\.(webm)(\?|$)/i.test(src)) { 
    return 'video/webm'; } return 'video/x-ms-asf-plugin'; } 

后台上传效果:

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/224070.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午12:45
下一篇 2026年3月17日 下午12:46


相关推荐

  • 接口测试用例设计方法有哪些_接口自动化测试用例设计

    接口测试用例设计方法有哪些_接口自动化测试用例设计本篇的目的是简明的完成一份接口测试用例设计的撰写,维护的文档,需要大家共同努力,不断完善,存在的不足以及日后在实际使用中暴露出来的问题,希望大家及时出,以便更新文档。一、用例设计过程:用例不是一次完成的,书写测试用例本身和完善代码一样,也是一个循序渐进的过程。首先,必须熟读需求说明书和接口设计文档,了解每个接口具体的使用场景,明白软件的性能指标。其次,设计接口测试用例:开始在编码阶段,测试人员根据需求说明书和接口设计文档设计接口测试用例。然后,codereview:开发完成编码后,在时间充裕的

    2025年11月12日
    5
  • Selenium PO模式

    Selenium PO模式SeleniumPO 模式

    2026年3月17日
    2
  • IAR for AVR delay函数「建议收藏」

    IAR for AVR delay函数「建议收藏」众所周知,在GCCAVR里有个delay.h的头文件,可以直接使用.IARforAVR里面只有__delay_cycles所以,我自己写了个delay.h,包含三个可调用的函数#ifndef__DELAY_H__#define__DELAY_H__#include#ifndefF_CPU#defineF_CPU        1

    2022年5月28日
    63
  • HDU-1498-50years,50colors(最大匹配, 枚举)

    HDU-1498-50years,50colors(最大匹配, 枚举)

    2021年7月6日
    88
  • r语言ggplot回归分析图_R如何导入数据

    r语言ggplot回归分析图_R如何导入数据#第一章R基础install.packages(c("ggplot2","gcookbook"))library(ggplot2)library(gcookbook)#加载分隔符式的文本文件#data&lt;-read.csv("datafile.csv")#data&lt;-read.csv("datafile.csv",header=FALSE)#手动为列名赋值#name…

    2022年10月3日
    3
  • 浏览器中beforeunload的使用

    浏览器中beforeunload的使用打开一些慢的网站的时候只见浏览器在不停转圈 但是页面还停留在当前页面的 有些网站的效果是你点击链接要跳到另一个页面的时候 在当前页面弹出一个框提示 正在加载中 用到了浏览器的 beforeunload 事件 自己试了一下 以下代码可运行源代码复制 IE 有效 打印关于 lt DOCTYPE nbsp html gt nbsp nbsp lt html nbsp lang en gt nbsp nbsp

    2026年2月10日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号