CKEditor实现图片上传以及预览

末蓝、 2022-07-24 06:05 556阅读 0赞

前言

CKEditor其实不需要多介绍,最早之前叫FCKEditor,后面改名了,其实就是一个富文本编辑器。

The best web text editor for everyone

上面是官网首页的内容,看上去挺牛逼的,其实也是,以前富文本编辑器还不是特别多,CKEditor算是老牌中的佼佼者吧,如今选择就有很多了,比如KindEditor,百度UEditor,CKEditor算是经典吧,功能也比较齐全,特别是兼容性特别好,个人觉得如今百度的UEditor做的越来越好了,不管是界面还是功能,所以用的人也越来越多了,所以有需要的人可以去了解了解,以后有时间可能再弄个UEditor的入门教程什么的。

环境

CKEditor4.4.6 标准版standard

官网下载:http://download.cksource.com/CKEditor/CKEditor/CKEditor 4.4.6/ckeditor_4.4.6_standard.zip

配置

1、适度精简、优化

  • 解压之后可以看到ckeditor/lang下面有很多语言的js,如果不需要那么多种语言的,可以只剩下en.js,zh.js,zh-cn.js
  • 图片上传时图像信息中的预览显示一堆英文信息,去掉
    找到ckeditor/plugins/image/dialogs/image.js,搜索“b.config.image_previewText”就能找到这段鸟语了,(b.config.image_previewText||”)单引号中的内容全删了,注意别删多了。

2、页面

引入ckeditor.js,当然你的路径可以跟我不一样。注意这里的textarea class=”ckeditor”是固定的。

  1. <script src="${pageContext.request.contextPath}/resources/ckeditor/ckeditor.js"></script>
  2. <textarea rows="10" cols="30" class="ckeditor" name="content" id="editor1"></textarea>

这里写图片描述

3、上传图片

如果没有配置上传图片的路径,默认点击上面的图片按钮,是没有上传子菜单的。

1、配置上传图片的路径

这里写图片描述

添加如下,当然路径是你controller/action的路径。

  1. // 上传图片路径
  2. config.filebrowserImageUploadUrl = "/back/news/imageUpload.do";

这里写图片描述

本来是没有上传子菜单Tab的,配置上传图片的路径之后,才会出现。

这里写图片描述

2、后台上传图片功能实现

Controller/Action

  1. /** * ckeditor图片上传 * * @Title imageUpload * @param request * @param response */
  2. @RequestMapping("imageUpload")
  3. public void imageUpload(HttpServletRequest request, HttpServletResponse response) {
  4. String DirectoryName = "upload/";
  5. try {
  6. ImageUploadUtil.ckeditor(request, response, DirectoryName);
  7. } catch (IllegalStateException e) {
  8. e.printStackTrace();
  9. } catch (IOException e) {
  10. e.printStackTrace();
  11. }
  12. }

ImageUploadUtil 图片上传工具类

  1. package com.news.util;
  2. import java.io.File;
  3. import java.io.IOException;
  4. import java.io.PrintWriter;
  5. import java.util.ArrayList;
  6. import java.util.Date;
  7. import java.util.Iterator;
  8. import java.util.List;
  9. import javax.servlet.http.HttpServletRequest;
  10. import javax.servlet.http.HttpServletResponse;
  11. import org.springframework.web.multipart.MultipartFile;
  12. import org.springframework.web.multipart.MultipartHttpServletRequest;
  13. import org.springframework.web.multipart.commons.CommonsMultipartResolver;
  14. /** * @ClassName: ImageUploadUtil * @Description: 图片上传工具类,包括ckeditor操作 */
  15. public class ImageUploadUtil {
  16. // 图片类型
  17. private static List<String> fileTypes = new ArrayList<String>();
  18. static {
  19. fileTypes.add(".jpg");
  20. fileTypes.add(".jpeg");
  21. fileTypes.add(".bmp");
  22. fileTypes.add(".gif");
  23. fileTypes.add(".png");
  24. }
  25. /** * 图片上传 * * @Title upload * @param request * @param DirectoryName * 文件上传目录:比如upload(无需带前面的/) upload/news .. * @return * @throws IllegalStateException * @throws IOException */
  26. public static String upload(HttpServletRequest request, String DirectoryName) throws IllegalStateException,
  27. IOException {
  28. // 创建一个通用的多部分解析器
  29. CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver(request.getSession()
  30. .getServletContext());
  31. // 图片名称
  32. String fileName = null;
  33. // 判断 request 是否有文件上传,即多部分请求
  34. if (multipartResolver.isMultipart(request)) {
  35. // 转换成多部分request
  36. MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest) request;
  37. // 取得request中的所有文件名
  38. Iterator<String> iter = multiRequest.getFileNames();
  39. while (iter.hasNext()) {
  40. // 记录上传过程起始时的时间,用来计算上传时间
  41. // int pre = (int) System.currentTimeMillis();
  42. // 取得上传文件
  43. MultipartFile file = multiRequest.getFile(iter.next());
  44. if (file != null) {
  45. // 取得当前上传文件的文件名称
  46. String myFileName = file.getOriginalFilename();
  47. // 如果名称不为“”,说明该文件存在,否则说明该文件不存在
  48. if (myFileName.trim() != "") {
  49. // 获得图片的原始名称
  50. String originalFilename = file.getOriginalFilename();
  51. // 获得图片后缀名称,如果后缀不为图片格式,则不上传
  52. String suffix = originalFilename.substring(originalFilename.lastIndexOf(".")).toLowerCase();
  53. if (!fileTypes.contains(suffix)) {
  54. continue;
  55. }
  56. // 获得上传路径的绝对路径地址(/upload)-->
  57. String realPath = request.getSession().getServletContext().getRealPath("/" + DirectoryName);
  58. System.out.println(realPath);
  59. // 如果路径不存在,则创建该路径
  60. File realPathDirectory = new File(realPath);
  61. if (realPathDirectory == null || !realPathDirectory.exists()) {
  62. realPathDirectory.mkdirs();
  63. }
  64. // 重命名上传后的文件名 111112323.jpg
  65. fileName = DateUtil.format(new Date(), DateUtil.DATE_FORMAT_1) + suffix;
  66. // 定义上传路径 .../upload/111112323.jpg
  67. File uploadFile = new File(realPathDirectory + "\\" + fileName);
  68. System.out.println(uploadFile);
  69. file.transferTo(uploadFile);
  70. }
  71. }
  72. // 记录上传该文件后的时间
  73. // int finaltime = (int) System.currentTimeMillis();
  74. // System.out.println(finaltime - pre);
  75. }
  76. }
  77. return fileName;
  78. }
  79. /** * ckeditor文件上传功能,回调,传回图片路径,实现预览效果。 * * @Title ckeditor * @param request * @param response * @param DirectoryName * 文件上传目录:比如upload(无需带前面的/) upload/.. * @throws IOException */
  80. public static void ckeditor(HttpServletRequest request, HttpServletResponse response, String DirectoryName)
  81. throws IOException {
  82. String fileName = upload(request, DirectoryName);
  83. // 结合ckeditor功能
  84. // imageContextPath为图片在服务器地址,如upload/123.jpg,非绝对路径
  85. String imageContextPath = request.getContextPath() + "/" + DirectoryName + "/" + fileName;
  86. response.setContentType("text/html;charset=UTF-8");
  87. String callback = request.getParameter("CKEditorFuncNum");
  88. PrintWriter out = response.getWriter();
  89. out.println("<script type=\"text/javascript\">");
  90. out.println("window.parent.CKEDITOR.tools.callFunction(" + callback + ",'" + imageContextPath + "',''" + ")");
  91. out.println("</script>");
  92. out.flush();
  93. out.close();
  94. }
  95. }

这里写图片描述

点击选择文件的时候,会打开资源管理器,然后选择一张图片,然后点击上传服务器,发现立马切换到图像信息的Tab页面,而且URL为图片存储的路径

这里写图片描述

这里注意上面的工具类中的ckeditor()方法,是回写一个script,用户回调,将图片的URL返回给CKEditor,实现预览的效果,也就是上面的效果。如果不这样做,是没有预览效果的。

CKEditor其他配置参考:
http://www.cnblogs.com/Setme/archive/2012/06/05/2536568.html

发表评论

表情:
评论列表 (有 0 条评论,556人围观)

还没有评论,来说两句吧...

相关阅读

    相关 图片实现

    闲话日常: 有时候在项目中,可能会用到图片上传的预览功能,而之前总是在网上找相关的插件进行实现,但是有的时候发现别人写好的插件,有时候会影响到自身布局的样式,偶尔还很难进