zoukankan      html  css  js  c++  java
  • CKEditor和CKFinder整合实现上传下载功能

    CKEditorCKFinder整合并实现文件上传功能

        事先说明:此整合的是java版本号的, 用到的有:jsp + ckeditor + ckfinder (没有servlet 及其他框架技术)

    一.须要的资源:

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

    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.1ckfinderCKFinderJavackfinder
    注意:CKFinder加粗的是war包解压后的目录的名称
    ckeditor_3.6.2/ckeditor
    3.复制CKFinder配置文件WEB-INF以下:
    ckfinder_java_2.1ckfinderCKFinderJavaWEB-INFconfig.xml
    4.复制以下目录以下全部jar文件到WEB-INf/lib以下:
    ckfinder_java_2.1ckfinderCKFinderJavaWEB-INFlib
    ckeditor-java-3.6.2WEB-INFlib
    三.以下删除没用的文件
    首先是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中添加例如以下代码:

    <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>
    六.改动ckeditor/config.js文件的内容
    CKEDITOR.editorConfig = function(config) {
    config.filebrowserBrowseUrl = '/CKEditor_Finder/ckfinder/ckfinder.html';
    config.filebrowserImageBrowseUrl = '/CKEditor_Finder/ckfinder/ckfinder.html?type=Images';
    config.filebrowserFlashBrowseUrl = '/CKEditor_Finder/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';
    // config.filebrowserWindowWidth = '1000';
    // config.filebrowserWindowHeight = '700';
       config.language = "zh-cn";
    };
    七.改动index.jsp文件的内容例如以下:
    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <%@ taglib uri="http://ckfinder.com" prefix="ckfinder" %>
    <%@ taglib uri="http://ckeditor.com" prefix="ckeditor" %>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <base href="<%=basePath%>">    
        <title>首页</title>
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">
    </head>
      <body>
    <%--<ckfinder:ckfinder basePath="/CKFinderJava_0100/ckfinder/" width="700" height="500" /> --%>
    <form action="getContent" method="get">
    <textarea cols="80" id="editor1" name="editor1" rows="10"></textarea>
    <input type="submit" value="Submit" />
    </form>
    <ckfinder:setupCKEditor basePath="/CKEditor_Finder/ckfinder/" editor="editor1" />
    <ckeditor:replace replace="editor1" basePath="/CKEditor_Finder/ckeditor/" />
      </body>
    </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.凝视这一部分,这样,在上传一中图片之后,中间就不会有提示了

    /*if (!S && (!p || a.bs.indexOf(p) % 8 < 4)) {
    P.mj = J;
    S = 1;
    }
    if ((P.eu && !T || S) && P.mj) { Q.addClass('files_message'); this.tools.of().setHtml(P.mj);
    }*/
    4.凝视掉这个部分:这样,左下角的东西就看不见了

    /*if (!B)this.dV().getChild(0).appendHtml(y || z || w != 4 ? r: s+ "74x62x3e"+i.htmlEncode(a.ed)+"7457x627674x2fx64151x76x3e");*/
    假设大家看不太明确  或者 是看着不舒服,能够到例如以下网址下载解说视频:(也想传到这个站点上,但是好像仅仅能上传图片,所以就传到其它的地方了)

    http://guoliang0-0-yahoo-cn.iteye.com/blog/1195348


  • 相关阅读:
    查看centos版本
    Internal.Cryptography.CryptoThrowHelper+WindowsCryptographicException 拒绝访问 / 出现了内部错误 c# – 当使用X509Certificate2加载p12/pfx文件时出现
    asp.net asp.net application 升级到 asp.net web 解决找不到控件 批量生成.designer文件
    netcore发布到 iis 设置 部署 环境 变量
    sqlserver 3145
    windows server 2012 远程桌面不好使
    VirtualBox 桥接模式,虚拟机ping不通宿主机
    移动端笔记
    css笔记——关于css中写上charset “utf-8”
    工作笔记——前端分页数据回显
  • 原文地址:https://www.cnblogs.com/blfshiye/p/4275744.html
Copyright © 2011-2022 走看看