CKEditor与CKFinder整合并实现文件上传功能




一.需要的资源:

用到的网站,文件自己下载:

a) ckeditor_3.6.2 (解压)
download.cksource.com/CKEditor/CKEditor/CKEditor%203.6.2/ckeditor_3.6.2.zip

b) ckeditor-java-3.6.2 (解压)
download.cksource.com/CKEditor/CKEditor%20for%20Java/CKEditor%20for%20Java%203.6.2/ckeditor-java-3.6.2.war

c) ckfinder_java_2.1 (解压)
download.cksource.com/CKFinder/CKFinder%20for%20Java/2.1/ckfinder_java_2.1.zip

二.执行步骤:
1.MyEclipse新建Web ProjectCKEditor_Finder
2.复制以下文件夹到WebRoot下面:
ckfinder_java_2.1\ckfinder\CKFinderJava\ckfinder
注意:CKFinder加粗的是war包解压后的文件夹的名称
ckeditor_3.6.2/ckeditor
3.复制CKFinder配置文件WEB-INF下面:
ckfinder_java_2.1\ckfinder\CKFinderJava\WEB-INF\config.xml
4.复制下面文件夹下面所有jar文件到WEB-INf/lib下面:
ckfinder_java_2.1\ckfinder\CKFinderJava\WEB-INF\lib
ckeditor-java-3.6.2\WEB-INF\lib
三.下面删除无用的文件
首先是ckeditor下面的文件:
_sample,_source, CHANGES.htmlckeditor_php4.php, ckeditor_php5.php,
ckeditor.asp, ckeditor.pack, INSTALL.html, LICENSE.html
然后是ckfinder下面的文件:
_samples, help, changelog.txt, install.txt, license.txt, translation.txt
四.修改配置文件config.xml
<enabled>true</enabled>
<baseURL>/CKEditor_Finder/userfiles/</baseURL>
五.在web.xml中增加如下代码:



[html]  view plain copy
  1. <servlet>    
  2. <servlet-name>ConnectorServlet</servlet-name> <servlet-class>com.ckfinder.connector.ConnectorServlet</servlet-class>    
  3. <init-param>    
  4. <param-name>XMLConfig</param-name>    
  5. <param-value>/WEB-INF/config.xml</param-value>    
  6. </init-param>    
  7. <init-param>    
  8. <param-name>debug</param-name>    
  9. <param-value>false</param-value>    
  10. </init-param>    
  11. <load-on-startup>1</load-on-startup>    
  12. </servlet>    
  13. <servlet-mapping>    
  14. <servlet-name>ConnectorServlet</servlet-name>    
  15. <url-pattern>    
  16. /ckfinder/core/connector/java/connector.java    
  17. </url-pattern>    
  18. </servlet-mapping>    
  19. <filter>    
  20. <filter-name>FileUploadFilter</filter-name> <filter-class>com.ckfinder.connector.FileUploadFilter</filter-class>    
  21.                 <init-param>    
  22.                     <param-name>sessionCookieName</param-name>    
  23.                     <param-value>JSESSIONID</param-value>    
  24.                 </init-param>    
  25.                 <init-param>    
  26.                     <param-name>sessionParameterName</param-name>    
  27.                     <param-value>jsessionid</param-value>    
  28.                 </init-param>    
  29. </filter>    
  30. <filter-mapping>    
  31. <filter-name>FileUploadFilter</filter-name>    
  32. <url-pattern>    
  33. /ckfinder/core/connector/java/connector.java    
  34.        </url-pattern>    
  35. </filter-mapping>    
  36. <session-config>    
  37. <session-timeout>10</session-timeout>    
  38. </session-config>    

六.修改ckeditor/config.js文件的内容



[javascript]  view plain copy
  1. CKEDITOR.editorConfig = function(config) {    
  2. config.filebrowserBrowseUrl = '/CKEditor_Finder/ckfinder/ckfinder.html';    
  3. config.filebrowserImageBrowseUrl = '/CKEditor_Finder/ckfinder/ckfinder.html?type=Images';    
  4. config.filebrowserFlashBrowseUrl = '/CKEditor_Finder/ckfinder/ckfinder.html?type=Flash';    
  5. config.filebrowserUploadUrl = '/ckfinder/core/connector/java/connector.java?command=QuickUpload&type=Files';    
  6. config.filebrowserImageUploadUrl = '/ckfinder/core/connector/java/connector.java?command=QuickUpload&type=Images';    
  7. config.filebrowserFlashUploadUrl = '/ckfinder/core/connector/java/connector.java?command=QuickUpload&type=Flash';    
  8. // config.filebrowserWindowWidth = '1000';    
  9. // config.filebrowserWindowHeight = '700';    
  10.    config.language = "zh-cn";    
  11. };  

[html]  view plain copy
  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>    
  2. <%@ taglib uri="http://ckfinder.com" prefix="ckfinder" %>    
  3. <%@ taglib uri="http://ckeditor.com" prefix="ckeditor" %>    
  4. <%    
  5. String path = request.getContextPath();    
  6. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";    
  7. %>    
  8. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">    
  9. <html>    
  10.   <head>    
  11.     <base href="<%=basePath%>">        
  12.     <title>首页</title>    
  13. <meta http-equiv="pragma" content="no-cache">    
  14. <meta http-equiv="cache-control" content="no-cache">    
  15. <meta http-equiv="expires" content="0">    
  16. </head>    
  17.   <body>    
  18. <%--<ckfinder:ckfinder basePath="/CKFinderJava_0100/ckfinder/" width="700" height="500" /> --%>    
  19. <form action="getContent" method="get">    
  20. <textarea cols="80" id="editor1" name="editor1" rows="10"></textarea>    
  21. <input type="submit" value="Submit" />    
  22. </form>    
  23. <ckfinder:setupCKEditor basePath="/CKEditor_Finder/ckfinder/" editor="editor1" />    
  24. <ckeditor:replace replace="editor1" basePath="/CKEditor_Finder/ckeditor/" />    
  25.   </body>    
  26. </html>    

http://localhost/CKEditor_Finder/
很可能或者可以说是肯定:您在访问之后操作的时候,不会像在我视频里面的那样顺利,尤其是关于中文问题,其中有一个重要的操作上面没有提及:
这个操作就是:找到Tomcat/config/server.xml  
<Connector port="80" protocol="HTTP/1.1" 
               connectionTimeout="20000" 
               redirectPort="8443" URIEncoding="utf-8" />
这个设置是为了在访问的时候,即使访问路径中出现中文也能正常访问.  如果还有其他问题,可以发贴继续交流一下^_^

关于破解:
替换方框的文字为:预览图片的位置。
要替换的文件的位置:/CKEditor_Finder/WebRoot/ckeditor/plugins/image/dialogs/image.js
Ckfinder.js文件的修改:
1.CKEditer/config.js文件大括号最后添加: 
     config.image_previewText = "预览图片的位置! 自己修改!! ";

(以下修改的文件均为:ckfinder/ckfinder.js文件)
2.return a.bF.length > 0 && A.indexOf(a.bF.substr(0, 9)) != -1 改为return false;
3.注释这一部分,这样,在上传一中图片之后,中间就不会有提示了



[html]  view plain copy
  1. /*if (!S && (!p || a.bs.indexOf(p) % 8 < 4)) {   
  2. P.mj = J;   
  3. S = 1;   
  4. }   
  5. if ((P.eu && !T || S) && P.mj) { Q.addClass('files_message'); this.tools.of().setHtml(P.mj);   
  6. }*/  

4.注释掉这个部分:这样,左下角的东西就看不见了


/*if (!B)this.dV().getChild(0).appendHtml(y || z || w != 4 ? r: s+ "\074\x62\x3e"+i.htmlEncod

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值