代码地址如下:
http://www.demodashi.com/demo/12427.html

使用struts2完成ckeditor和ckeditor图片上传

ckeditor版本ckeditor_4.8.0_full

struts2版本struts2.5

  • 解压压缩包,将解压后的文件夹ckeditor直接拷贝至WebContent下
  • 在jsp中引用ckeditor.js
  1. <script type="text/javascript" src="${pageContext.request.contextPath }/js/ckeditor/ckeditor.js"></script>
  • 在文本域textarea下方编写如下js代码
  1. <script type="text/javascript">CKEDITOR.replace("editor");</script>

注意:replace中写的是textarea的name名称

  • 完整代码:

  • 在demo.action中设置属性,名称为editor,提供getter和setter方法
  • 在struts.xml中配置好action
  1. <action name="demo" class="demo.DemoAction" method="demo">
  2. <result>/result.jsp</result>
  3. </action>
  • 启动服务器查看效果:

在jsp页面中可以不必写提交按钮,上方有一个保存,效果相同,需要使用editor full版本,该版本相较于标准版本功能更多。

点击保存即可在result.jsp界面中查看,后台打印是html样式。

解决图片上传

  • 上传按钮显示解决(默认是没有图片上传的)

在editor文件夹目录下的config.js中添加如下代码:

  1. config.filebrowserUploadUrl="ckeditorUpload.action";
  2. //url地址为一会上传至服务器执行的action
  • 图片预览中英文解决

在editor文件夹目录下的config.js中添加如下代码:

  1. config.image_previewText=' ';
  • 效果

  • 实现上传功能

上面的只是一个上传页面。也就相当于一个HTML的form表单,要配置点击“上传到服务器上”按钮后请求的Action。可以在ckeditor/config.js中配置。该表单的上传标签的name为upload。

在config.js中添加如下代码:

  1. config.filebrowserUploadUrl="ckeditorUpload.action";
  2. //url地址为一会上传至服务器执行的action

该行代码其实在上传按钮显示时就已经配置过。

  • struts.xml中代码:
  1. <action name="ckeditorUpload" class="demo.DemoAction" method="upload">
  2. </action>
  • 文件上传代码,思路与struts文件上传相同,只需要加上几句即可,代码如下:
  1. private File upload; //editor默认的上传表单的标签名为upload
  2. private String uploadContentType;
  3. private String uploadFileName;
  4. public File getUpload() {
  5. return upload;
  6. }
  7. public void setUpload(File upload) {
  8. this.upload = upload;
  9. }
  10. public String getUploadContentType() {
  11. return uploadContentType;
  12. }
  13. public void setUploadContentType(String uploadContentType) {
  14. this.uploadContentType = uploadContentType;
  15. }
  16. public String getUploadFileName() {
  17. return uploadFileName;
  18. }
  19. public void setUploadFileName(String uploadFileName) {
  20. this.uploadFileName = uploadFileName;
  21. }
  22. public String upload() throws Exception{
  23. HttpServletResponse response = ServletActionContext.getResponse();
  24. response.setCharacterEncoding("GBK");
  25. PrintWriter out = response.getWriter();
  26. String realPath=ServletActionContext.getServletContext().getRealPath("/images");
  27. File file = new File(realPath);
  28. // CKEditor提交的很重要的一个参数
  29. String callback = ServletActionContext.getRequest().getParameter("CKEditorFuncNum");
  30. //request.put("callback", callback);
  31. FileOutputStream fout=
  32. new FileOutputStream(new File(file,getUploadFileName()));
  33. FileInputStream in=new FileInputStream(getUpload());
  34. byte[] buffer=new byte[1024];
  35. int len=0;
  36. while((len=in.read(buffer))>0)
  37. fout.write(buffer,0,len);
  38. //返回“图像”选项卡,并显示预览图片
  39. //一定要在流关闭之前写下面三句话,否则图片显示不出来,也不报错
  40. out.println("<script type=\"text/javascript\">");
  41. out.println("window.parent.CKEDITOR.tools.callFunction(" + callback + ",'" + ServletActionContext.getRequest().getContextPath() + "/images/" + uploadFileName + "','')");
  42. out.println("</script>");
  43. out.close();
  44. in.close();
  45. return SUCCESS;
  46. }
  • 效果截图:

  • 点击上传到服务器,自动跳转至图像信息选项卡,并显示预览图片

  • 点击确定:

  • 点击保存,即可在result.jsp页面中查看:

  • 控制台打印文本域中的信息:

项目结构



使用struts2完成ckeditor和图片上传

代码地址如下:
http://www.demodashi.com/demo/12427.html

注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权

使用struts2完成ckeditor和图片上传的更多相关文章

  1. CKEditor实现图片上传

    本人用的CKEditor版本为4.3 CKEditor配置和部署参考CKEditor4.x部署和配置. CKEditor编辑器的工具栏中初始的时候应该是这样子的,没有图片上传按钮 并且预览中有一堆火星 ...

  2. ckeditor 实现图片上传以及预览(亲测有效)

    引用ckeditor <script type="text/javascript" src="static/ckeditor/ckeditor.js"&g ...

  3. struts2+ckeditor配置图片上传

    又是一个漫漫长夜. 公司的编辑器坏了,用的是百度编辑器,上传图片的网址被框架给拦截了,我们本地怎么测试都没问题,放到服务器就这样了.和老李找了半天,疯了,没原因的. 笔者以前用过jsp+ckedito ...

  4. CKEditor粘贴图片上传功能

    很多时候我们用一些管理系统的时候,发布新闻.公告等文字类信息时,希望能很快的将word里面的内容直接粘贴到富文本编辑器里面,然后发布出来.减少排版复杂的工作量. 下面是借用百度doc 来快速实现这个w ...

  5. struts2 使用ajax进行图片上传

    第一步:引入一个插件    jquery.form.js /*! * jQuery Form Plugin * version: 3.36.0-2013.06.16 * @requires jQuer ...

  6. WINDOW.PARENT.CKEDITOR.TOOLS.CALLFUNCTION 图片上传

    CKEDITOR  编辑器   图片上传 WINDOW.PARENT.CKEDITOR.TOOLS.CALLFUNCTION (CKEditorFuncNum,图片路径,返回信息); CKEditor ...

  7. CKEditor与dotnetcore实现图片上传

    CKEditor的使用 1.引入js库 <script src="https://cdn.ckeditor.com/4.6.1/standard-all/ckeditor.js&quo ...

  8. CKEditor图片上传问题(默认安装情况下编辑器无法处理图片),通过Base64编码字符串解决

    准备做一个文章内容网站,网页编辑器采用CKEditor,第一次用,默认安装情况下,图片无法插入,提示没有定义上传适配器(adapter),错误码提示如下: 根据提示,在官网看到有两种途径:一使用CKE ...

  9. 大图片上传(ImageIO,注意有的图片不能上传时因为他是tiff格式)

    一下是必要的: 1.enctype="multipart/form-data" 2. //不要使用myeclipse自动生成的get.set方法(struts2中的用法) publ ...

随机推荐

  1. BZOJ4540 [Hnoi2016]序列 【莫队 + ST表 + 单调栈】

    题目 给定长度为n的序列:a1,a2,-,an,记为a[1:n].类似地,a[l:r](1≤l≤r≤N)是指序列:al,al+1,-,ar- 1,ar.若1≤l≤s≤t≤r≤n,则称a[s:t]是a[ ...

  2. bzoj 4465 游戏中的学问(game)

    题目描述 输入 输出 样例输入 3 1 1000000009 样例输出 2 提示 solution 令f[i][j]表示i个人围成j个圈的方案数 啥意思呢 可以把一个人塞进前面的圈里(i-1种塞法) ...

  3. $.extend(object) 和 $.fn.extend(object)

    1.jQuery.extend(object); 它是为jQuery类添加类方法,可以理解为添加静态方法.如: jQuery.extend({ min: function(a, b) { return ...

  4. Jib构建你的第一个java镜像

    jib Official:GoogleContainerTools/jib 本文示例完整demo github地址 github.com/moxingwang/- 想要了解并且使用jib,首先你得知道 ...

  5. [网络流24题] COGS 搭配飞行员

    14. [网络流24题] 搭配飞行员 ★★☆   输入文件:flyer.in   输出文件:flyer.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述]     飞行大队 ...

  6. javascript草稿

    原文发布时间为:2011-06-01 -- 来源于本人的百度文章 [由搬家工具导入]   @MyHelper.Script("jquery-1.6.1.min.js", Url)  ...

  7. hdu 1395(欧拉函数)

    2^x mod n = 1 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  8. layui如何使用内部jQuery?

    遇到问题情境: 由于Layui部分内置模块依赖jQuery,所以没有单独引入jQuery,但是在使用$常规写法获取dom元素时,提示未定义 出现问题的原因: 由于Layui部分内置模块依赖jQuery ...

  9. go 函数回调

  10. Spring Cloud Feign 声明式服务调用

    目录 一.Feign是什么? 二.Feign的快速搭建 三.Feign的几种姿态 参数绑定 继承特性 四.其他配置 Ribbon 配置 Hystrix 配置 一.Feign是什么? ​ 通过对前面Sp ...