`
HuNanPengdake
  • 浏览: 235810 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

SSH下整合CKEditor+CKFinder问题

阅读更多
[color=darkblue]文章转自:http://sky-yangwang.iteye.com/blog/1489925

当然,我也不知道这篇文章的原始出处了,大概是经过很多人修改,测试过的吧。

[size=small]1,ckeditor:

1),http://ckeditor.com/download

CKEditor for Java ;---3.6.2下载;---ckeditor-java-3.6.2.war使用Tomcat分发包;---得到ckeditor-java-3.6.2文件内容;

2),复制ckeditor文件夹到项目web根路径下;

3),复制ckeditor-java-core-3.5.3.jar类库到项目web-inf下。

2,ckfinder:

1),http://ckfinder.com/download

Java;---2.2.1下载;---ckfinder_java_2.2.1.zip解压;---CKFinderJava.war使用Tomcat分发包;---得到CKFinderJava文件;

2),ckfinder

2),复制ckfinder文件夹到项目web根路径下;

3),复制lib下的类库到项目web-inf下(commons-fileupload-1.2.2.jar和commons-io-2.0.1.jar已有,不用复制)。

3,复制CKFinderJava\WEB-INF\config.xml到项目的web-inf下:

Config.xml配置修改:

<enabled>true</enabled>;---开启上传;

<baseURL>/sshWeb/WebsiteBackstage/userfiles/</baseURL>---上传文件存放位置;

上传文件、图片、flash的类型配置(先不动);

4,ckeditor\config.js修改:
CKEDITOR.editorConfig = function( config )

{

// Define changes to default configuration here. For example:

// config.language = 'fr';

// config.uiColor = '#AADC6E';

config.language =  "zh-cn" ; 

config.filebrowserWindowWidth = '1000';  

    config.filebrowserWindowHeight = '700'; 

    

config.filebrowserBrowseUrl =  '/sshWeb/ckfinder/ckfinder.html' ;  

    config.filebrowserImageBrowseUrl =  '/sshWeb/ckfinder/ckfinder.html?type=Images' ;  

    config.filebrowserFlashBrowseUrl =  '/sshWeb/ckfinder/ckfinder.html?type=Flash' ;  

    config.filebrowserUploadUrl =  '/ckfinder/core/connector/java/connector.java?command=QuickUpload&type=Files' ;  

    config.filebrowserImageUploadUrl =  '/ckfinder/core/connector/java/connector.java?command=QuickUpload&type=Images' ;  

    config.filebrowserFlashUploadUrl =  '/ckfinder/core/connector/java/connector.java?command=QuickUpload&type=Flash' ;     

};

参考文章:

http://www.cnblogs.com/yezhenhan/archive/2011/12/10/2282986.html

----------------------------------------------------------------------------------------------------

5,Js写法的页面代码:
<script src="../../ckeditor/ckeditor.js" type="text/javascript"></script>

<script src="../../ckfinder/ckfinder.js" type="text/javascript"></script>

<script src="../js/jquery-1.7.2.js" type="text/javascript"></script>  

<script src="../../ckeditor/adapters/jquery.js" type="text/javascript"></script> 

<s:form action="about_add">

     <s:textfield name="aboutUs.title" label="标题"/>

      <s:textarea name="aboutUs.content" rows="30" cols="50" label="内容"/>

      <script type="text/javascript">  

                 $('#editor').ckeditor();  

                 var editor = CKEDITOR.replace('aboutUs.content');

                 CKFinder.setupCKEditor(editor, '/sshWeb/ckfinder/');

            </script>

     <s:submit/>

</s:form>

6,Web.xml配置:

---struts2与servlet并存解决方法:使用自定义过滤器,将web.xml中添加的ckfinder的servlet过滤内容从struts2过滤中排除;
<filter>  

        <filter-name>MyServlet</filter-name>  

       <filter-class>util.ReDispatcherFilter</filter-class>  

        <init-param>  

      <param-name>includeServlets</param-name>  

       <param-value>connector.java</param-value>  

       </init-param>  

    </filter>  

  <filter-mapping>  

       <filter-name>MyServlet</filter-name>  

        <url-pattern>/*</url-pattern>  

   </filter-mapping>  

      

       <filter>

        <filter-name>struts2</filter-name>

        <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>

   </filter>

   <filter-mapping>  

       <filter-name>struts2</filter-name>  

       <url-pattern>*.action</url-pattern>  

   </filter-mapping>

    <filter-mapping>

        <filter-name>struts2</filter-name>

        <url-pattern>/*</url-pattern>

    </filter-mapping>  

    

    

    <servlet>

<servlet-name>ConnectorServlet</servlet-name>

<servlet-class>com.ckfinder.connector.ConnectorServlet</servlet-class>

<init-param>

<param-name>XMLConfig</param-name>

<param-value>/WEB-INF/config.xml</param-value>

</init-param>

<init-param>

<param-name>debug</param-name>

<param-value>false</param-value>

</init-param>

<load-on-startup>1</load-on-startup>

</servlet>

<servlet-mapping>

<servlet-name>ConnectorServlet</servlet-name>

<url-pattern>

/ckfinder/core/connector/java/connector.java

</url-pattern>

</servlet-mapping>

<filter>

<filter-name>FileUploadFilter</filter-name>

<filter-class>com.ckfinder.connector.FileUploadFilter</filter-class>

                <init-param>

                    <param-name>sessionCookieName</param-name>

                    <param-value>JSESSIONID</param-value>

                </init-param>

                <init-param>

                    <param-name>sessionParameterName</param-name>

                    <param-value>jsessionid</param-value>

                </init-param>

</filter>

<filter-mapping>

<filter-name>FileUploadFilter</filter-name>

<url-pattern>

/ckfinder/core/connector/java/connector.java

       </url-pattern>

</filter-mapping>

<session-config>

<session-timeout>10</session-timeout>

</session-config>

    <welcome-file-list>

        <welcome-file>index.html</welcome-file>

</welcome-file-list>

7,自定义过滤器:
import java.io.IOException;

import java.util.ArrayList;

import java.util.Arrays;

import javax.servlet.Filter;

import javax.servlet.FilterChain;

import javax.servlet.FilterConfig;

import javax.servlet.RequestDispatcher;

import javax.servlet.ServletException;

import javax.servlet.ServletRequest;

import javax.servlet.ServletResponse;

import javax.servlet.http.HttpServletRequest;

public class ReDispatcherFilter implements Filter {

public void destroy() {

   // TODO Auto-generated method stub

}

public void doFilter(ServletRequest req, ServletResponse resp,

    FilterChain chain) throws IOException, ServletException 

{

  

   HttpServletRequest request = (HttpServletRequest)req;

   String target = request.getRequestURI();

   target = target.lastIndexOf("?")>0   

      ?target.substring(target.lastIndexOf("/")+1,target.lastIndexOf("?")-target.lastIndexOf("/"))

      :target.substring(target.lastIndexOf("/")+1);

  

   System.out.println(target);

   if(this.includes.contains(target))

   {

    RequestDispatcher rdsp = request.getRequestDispatcher(target);

   

    System.out.println("go..............."+rdsp);

    rdsp.forward(req, resp);

   }

   else

    chain.doFilter(req, resp);

}

private ArrayList<String> includes = new ArrayList<String>();

public void init(FilterConfig config) throws ServletException {

  

   this.includes.addAll( Arrays.asList(config.getInitParameter("includeServlets").split(",")));

}

}

参考文章:

ssh&ckfinder&ckeditor struts2与servlet并存解决方法

http://blog.csdn.net/databaseyan/article/details/6914654

http://hi.baidu.com/xsl2007/blog/item/4eb796cf94e35f0992457e11.html

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////

其它问题:

上传文件中文名问题;

上传文件位置问题;

单纯Ckeditor的使用:

下载最新的ckeditor文件: http://ckeditor.com/download

解压后复制到web层根目录下;

页面引用js:
<script src="ckeditor/ckeditor.js" type="text/javascript"></script>

替换TEXTAREA标签:
<textarea rows="30" cols="50" name="editor01">请输入.</textarea>
<script type="text/javascript">CKEDITOR.replace('editor01');</script>
分享到:
评论

相关推荐

    ckeditor+ckfinder组合下载 (php演示版,2019年最新,绝对好用) ckeditor4+ckfinder3.1

    CKEditor和CKFinder是两个非常流行的开源Web编辑器和文件管理工具,它们在网页内容编辑和上传文件方面提供了强大的功能。CKEditor是一个富文本编辑器,而CKFinder则作为一个插件,为CKEditor提供了一个方便的文件...

    ckeditor+ckfinder精简版 ckeditor+ckfinder精简版

    总的来说,CKEditor+CKFinder精简版为开发者提供了一个轻量级但功能实用的在线文本编辑和文件管理解决方案,适合那些追求效率和性能的Web应用。通过适当的配置和定制,可以将其无缝融入你的项目中,提升用户体验。

    ckeditor + ckFinder asp版

    值得注意的是,这个asp版本的ckeditor+ckFinder组合特别强调了UTF编码的支持。UTF(Unicode Transformation Format)是一种广泛使用的字符编码标准,可以处理世界上几乎所有的字符集,确保了内容的全球化和跨文化...

    整合ckeditor+ckfinder实现图片或文件上传功能

    总之,通过`ckeditor`和`ckfinder`的整合,你可以为JAVA工程提供一个强大的富文本编辑体验,同时具备图片和文件的上传管理功能。在实际开发过程中,需要注意兼容性、性能优化以及安全性,以确保用户体验和系统稳定。

    ckeditor+ckfinder(java 版本)

    **ckeditor+ckfinder(java 版本)** **一、CKEditor与CKFinder简介** CKEditor是一款功能丰富的开源富文本编辑器,它支持多种浏览器环境,提供了丰富的文本编辑功能,包括文字格式化、图像处理、链接创建等。...

    ckeditor+ckfinder 完美组合编辑器 加图片上传功能

    "ckeditor+ckfinder"就是一个强大的组合,专为提高网页内容编辑体验而设计,特别是对于需要处理多媒体资源如图片上传的场景。本文将详细介绍这个组合以及其主要功能。 **ckeditor** 是一款知名的开源富文本编辑器,...

    最新asp.net版Ckeditor+ckfinder

    总结来说,"最新asp.net版Ckeditor+ckfinder"的组合为ASP.NET开发人员提供了一个高效、易用的富文本编辑解决方案,使得在网页上创建和管理内容变得更加便捷。无论是新手还是经验丰富的开发者,都能从中受益,实现高...

    ckeditor+ckfinder 文本编辑器和图片编辑器

    CKEditor和CKFinder是两个非常重要的工具,常用于构建网页内容管理系统或在线应用程序中的文本编辑和图像管理功能。CKEditor是一款强大的富文本编辑器,而CKFinder则是一个配套的文件管理器,尤其适用于图片的上传、...

    最新c#整合ckeditor+ckfinder示例

    本示例聚焦于"C#"环境下如何整合CKEditor和CKFinder,这是一套强大的编辑器与文件管理器组合,适用于创建具有高级文本编辑功能和图片/文件上传功能的网页应用程序。 CKEditor是一款知名的开源JavaScript富文本编辑...

    ckeditor+ckfinder+ssh框架

    【ckeditor+ckfinder+ssh框架】的组合是用于构建一个功能强大的在线文本编辑器的解决方案,它可以提供类似于Microsoft Word的编辑体验,并且支持图片和其他媒体文件的上传功能。以下是这个集成的具体实现步骤和相关...

    ckeditor+ckFinder2.1 破解版

    ckeditor+ckFinder2.1 破解版 java 能运行

    ckeditor+ckfinder 结合破解版

    ckfinder结合已经做好,可以直接使用

    最新版本ckeditor+ckfinder,集成上传功能

    同时,`安装说明.txt`提供了详细的步骤指导,包括如何配置ckfinder与ckeditor的连接,以及可能遇到的问题和解决方案。 `upfiles`文件夹通常是用来存储用户上传的文件和图片的,ckfinder会读取并管理这个目录中的...

    CKEditor+CKFinder+jsp的整理

    CKEditor+CKFinder+jsp的整理

    ckeditor+ckfinder配置

    **ckeditor+ckfinder配置详解** 在网页编辑领域,CKEditor是一款广泛应用的富文本编辑器,它提供了丰富的文本格式化选项,使得用户可以在网页上轻松创建和编辑内容。CKFinder则是一个与CKEditor配套的文件管理工具...

    SSH+URLWriter+AJAX+CKEditor+CKFinder配置示例

    其中使用了Struts2+Spring3+Hibernate3+DWR3+CKeditor3+CKFinder2等技术。 本资料主要是框架的配置文件示例。在系统中已经运行成功。 有疑问的请联系QQ四九八三5七七七九 或邮件:microsoftsun@163.com

    phpbypjmf+ckeditor+ckfinder完全破解整合版

    phpbypjmf+ckeditor+ckfinder完全破解整合版,好不容易找到的,很容易用在网站中。

    最强大WEB编辑器Ckeditor+ckfinder ASP.NET破解版

    最强大WEB编辑器Ckeditor+ckfinder ASP.NET破解版,就是一个vs2010的项目解压下载后就可以使用。已经破解了,不用再有版权问题,能给大家一个满意的好资源

    Ckeditor+ckfinder例子

    5. 在网页中测试CKEditor+CKFinder的组合,验证富文本编辑、资源上传和自动重命名功能是否正常运行。 这个例子对于开发者来说是一个很好的学习资源,它展示了如何根据项目需求定制CKEditor和CKFinder的功能,同时也...

    SharePoint2013集成CKEditor+CKFinder

    SharePoint2013+CKEditor+CKFinder+完美破解+按用户动态创建上传目录.

Global site tag (gtag.js) - Google Analytics