转载链接:https://blog.csdn.net/saytime/article/details/51416411

前言

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”是固定的。

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

3、上传图片

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

1、配置上传图片的路径

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

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

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

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

Controller/Action

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

ImageUploadUtil 图片上传工具类

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

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

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

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

版权声明:本文为博主原创文章,转载请注明出处http://blog.csdn.net/saytime https://blog.csdn.net/saytime/article/details/51416411

CKEditor上传图片相关推荐

  1. ckeditor上传图片文件,研究了一天,终于...

    ckeditors是一款非常好的工具,但是就是上传文件太遗憾了.找了很多关于ckeditor上传图片的例子,就是没有一个完整的demo. 今天终于弄出来了,供大家分享,这里就不写代码了,直接上传例子. ...

  2. php用ckeditor无法上传大图片,php ckeditor上传图片文件大小限制修改

    php ckeditor上传图片文件大小限制修改ckeditor编辑器在上传图片或文件时是没有大小限制的,下面我们来给大家介绍两种ckeditor上传图片文件大小限制问题解决办法. 一种可以通过修改P ...

  3. 毕业设计(十七)---发表文章(3)之- 使用ckeditor上传图片(flash)

    2019独角兽企业重金招聘Python工程师标准>>> 例子下载地址! 在发表文章的时候,经常会使用到图片, ckeditor本身提供了这个功能,需要开启,然后再加上自己一些代码. ...

  4. 自定义CKeditor上传图片按钮

    背景:之前公司的项目中用的是KindEditor富文本编辑器,后来发现有上传漏洞,所以项目中用了CKeditor富文本编辑器.But 发现自带的上传图片按钮并不能将上传的图片保存到服务器上,So 下面 ...

  5. php ckeditor 上传图片,CKEditor图片上传的PHP实现

    编辑文章是网站后台的常用功能,CKEditor是目前流行的富文本编辑器,它使用方便但要做一些配置才能实现上传本地图片到服务器的功能.在参考了一篇java下CKEditor图片上传的博文后,我用PHP实 ...

  6. ckeditor上传图片示例

    1.修改config.js CKEDITOR.editorConfig = function (config) {// Define changes to default configuration ...

  7. 上传服务器响应失败,Django CKEditor 上传图片提示“不正确的服务器响应”的解决办法...

    开发环境 django 1.11 django-ckeditor 5.3.1(CKEditor 4.7.3) 发生背景 前端页面引用了 CKEditor 富文本编辑器,Django 未登录的时候上传文 ...

  8. laravel ckeditor上传图片

    1.模板 <div class="form-group"><label for="content" class="col-sm-2 ...

  9. CKEditor上传图片—配置CKFinder

    参考:http://blog.csdn.net/gavin710/article/details/8741738 转载于:https://www.cnblogs.com/ChineseMoonGod/ ...

最新文章

  1. OUTER在mysql_MySQL不支持OUTER APPLY
  2. WijmoJS 使用Web Workers技术,让前端 PDF 导出效率更高效
  3. nedata实时监控服务器运行情况
  4. oracle错误处理及实操-【INS-20802】
  5. 设计模式之_工厂系列_01
  6. 减少工作时间更有利于百姓
  7. java利用反射映射两个不同对象的属性值
  8. 详解二叉树的递归遍历与非递归遍历——(二)
  9. Mac安装HomeBrewHomeBrew安装yarn
  10. (解决)Circular view path [index]: would dispatch back to the current handler URL [] again. Che
  11. 十大算法简单介绍以及例题
  12. windows服务器系统发展史,从1.0到Win10:Windows操作系统进化史
  13. 2种Android图表的简单介绍+折线图、饼图的例子,字节跳动移动架构师学习笔记
  14. css3-animation-复习篇
  15. 在线博客系统——获取用户信息,退出登录
  16. 1N系列稳压二极管参数
  17. storm spout读取mysql_java – Storm:用于从端口读取数据的Spout
  18. 学习Java用什么软件?
  19. Lucene Query Parser Syntax
  20. 模拟音频处理器:Excite Audio Lifeline Console Mac

热门文章

  1. 泛微E-Mobile4.5服务端安装手册
  2. 一个程序猿必须会玩的游戏
  3. MOS管的作用及原理介绍
  4. 智能座舱自动化测试解决方案的硬件构成
  5. 2017年12月21ri心得体会
  6. Python绘图库:Matplotlib
  7. 使用C语言+EasyX完成消灭星星游戏(3)
  8. 鲁豫有约80后创业新贵(下)
  9. Xshell 使用小技巧
  10. 手机QQ访问时,html页面在QQ中自定义预览和自定义分享