• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    FCKeditor .NET的配置、扩展与安全性经验交流
    前言
    FCKeditor是使用非常广泛的HTML编辑器,本文从 ASP.NET 的使用场景对 FCKeditor 与 FCKeditor.NET 的配置、功能扩展(如自定义文件上传子目录、自定义文件名、上传图片的后期处理等)、以及安全性进行初步的阐述。

    希望能帮助有同样需求的同仁节省一点时间;也希望各位能指正其中的不足。谢谢。

    一、自定义 FCKeditor 的 BasePath
    BasePath 即FCKeditor在网站中的相对路径,默认值是 /fckeditor/,最好在Web.config appSettings中对其进行配置:

    add key="FCKeditor:BasePath" value="/FCKeditor_2.6.3/"/>

    这样做有诸多优点:

    开发环境与生产环境不同,开发环境一般是http://localhost/xxx.com/这种情况下FCKeditor就得放在一个虚拟目录http://localhost/fckeditor/中,若涉及多个网站的开发,而各网站的FCKeditor有差别时,这样显然不是最优;
    而且因为物理目录结构与逻辑目录结构不同,也会有发生错误的隐患;
    而如果采用Web.config的配置,就可以在开发环境采用不同的配置,FCKeditor的物理路径与生产环境保持一致;
    当升级FCKeditor时,只需要将新版本的FCKeditor放在相应版本号的目录里,修改一下配置即可。这样可以解决因为静态资源的客户端缓存问题,不同用户出现不同的错误的问题;
    可以直观地看到自己的FCKeditor的版本号。

    二、配置文件上传的目录
    FCKeditor的文件上传(如图片上传)目录可以通过Web.config appSettings进行配置,如:

    add key="FCKeditor:UserFilesPath" value="/UploadFile/FCKeditor/"/>

    也可以在 /FCKeditorBasePath/editor/filemanager/connectors/aspx/config.ascx 中进行配置,但我建议 FCKeditor 目录中的内容能不改就不改(fckconfig.js除外),这样日后升级可以放心地替换即可。

    三、自定义文件上传的子目录的格式
    我们知道,一个文件夹下面不能存放过多的文件(据称Windows下面的目录下2000为阈值),否则对该目录的访问会严重影响I/O性能。而FCKeditor的文件存储是在单一的一个目录进行的。我对FCKeditor进行了扩展,可以在Web.config appSettings对存储目录的格式自定义,如:

    add key="FCKeditor:FolderPattern" value="%y/%m-%d/"/>
    ========================================
    以今天的日期为例:这样产生的文件上传子目录格式为:2008/10-21/。
    年月日格式的目录可以随意组合,如:
    add key="FCKeditor:FolderPattern" value="%y/%m/%d/"/>
    这样产生的文件上传子目录变成了2008/10/21/
    ========================================
    还可以针对不同登录的用户,采用不同的上传子目录
    Web.config 修改上传子目录的配置,增加%u表示不同用户使用基于其标识不同的上传子目录

    add key="FCKeditor:FolderPattern" value="%u/%y/%m/%d/"/>
    FCKeditor_2.6.3\editor\filemanager\connectors\aspx\config.ascx 中增加获取当前登录用户标识的逻辑
    复制代码 代码如下:

    public override void SetConfig()
    {
    #region Bochuh's Modification
    // Identifier for logined user
    // Leave blank for default user upload folder
    LoginedUserIdentifier = "44"; // 这里替换成获取当前登录用户表示的代码
    #endregion

    // ……此文件中原来的代码
    }

    这样可以对不同用户,根据其登录后的标识(一般是用户ID),来使用不同的目录进行存储,如:7394/2008/10/21/(7394是当前登录用户的ID)
    参考:
    %u 代表 当前登录用户的标识
    %y 代表 当前时间的年份
    %m 代表 当前时间的月份
    %d 代表 当前时间的日
    四、自定义文件上传的文件名格式
    FCKeditor对文件名的处理规则是:如果当前目录下没有重名文件,则上传后的文件名与用户PC上的文件名一致;若存在n个重名文件,则加入用户PC上的文件名是Example.xxx,上传后的文件名变为:Example(n).xxx
    我的项目里要求对用户上传的文件名变成Guid的格式,所以我对FCKeditor也做了扩展,在Web.config appSettings可以对上传后文件的格式自定义,如:
    add key="FCKeditor:FilenamePattern" value="%guid.%extl"/>
    这样的文件名如:a299e63a-7d2d-493d-bbb9-99162ef5b6b8.gif
    参考:
    %guid 代表 一个新的guid字符串
    %fnl 代表 源文件名的小写
    %fnu 代表 源文件名的大写
    %extl 代表 源文件扩展名的小写
    %extu 代表 源文件扩展名的大写
    五、对上传图片进行缩放处理
    用到FCKeditor图片上传功能的场景中,很多是内容的发表。内容中往往不需要几千像素大小的图片,比如我的项目中,文章区域最宽也就560像素,所以我做了一个扩展,在Web.config appSettings中可以对图片的最大宽度进行自定义:
    add key="FCKeditor:MaxWidthOfUploadedImg" value="560"/>
    有了这段配置,上传后的图片的宽度都控制在了560像素及以内

    六、自定义上传后图片URL中的域名
    为了加快页面的渲染,我们可以把图片等静态资源放在一个独立的域名当中。但FCKeditor默认的图片上传后URL是相对路径,如图:

    我增加了这个扩展,在Web.config appSettings可以配置上传后图片URL的域名,如:

    add key="FCKeditor:UploadedFilesDomain" value="http://a.cvimg.cn/"/>
    如图:

     
    七、解决上传文件名含有中文的文件时提示 "invalid file type" 的问题
    这个问题只需要在Web.config中增加一段配置即可解决:

    复制代码 代码如下:

    location path="FCKeditor_2.6.3/editor/filemanager/connectors/aspx/upload.aspx">
    system.web>
    globalization requestEncoding="utf-8" responseEncoding="gb2312"/>
    /system.web>
    /location>

    注意:
    responseEncoding是网站的默认编码
    FCKeditor_2.6.3是FCKeditor的BasePath

    八、FCKeditor的安全性
    在FCKeditor的2.3.2版本里,曾有一个漏洞,可以通过 /editor/filemanager/browser/default/connectors/aspx/connector.aspx 往服务器上传任意文件,我的网站就曾经中招。
    2.6.3虽然暂未发现类似的问题,但一般情况下用不到的文件最好还是删除比较好:

    FCKeditor BasePath 根目录中除了保留:
    /editor
    /fckconfig.js
    /fckpackager.xml
    /fckstyles.xml
    /fcktemplates.xml
    /license.txt
    外,全部删除
    /editor/filemanager/中除了保留:
    /connectors/aspx/config.ascx
    /connectors/aspx/upload.aspx
    外,全部删除
    删除 /editor/_source/
    /editor/filemanager/connectors/aspx/config.ascx 的 CheckAuthentication() 方法中,增加验证用户是否登录的逻辑
    注意:以上措施仅适用于ASP.NET的网站,其他语言版本的网站未考虑。

    附:基于FCKeditor.Net_2.6.3修改后的源码
    SOURCE: http://xiazai.jb51.net/201108/yuanma/FCKeditor.Net_2.6.3_20090713.zip
    BIN(.NET 2.0): http://xiazai.jb51.net/201108/yuanma/FredCK.FCKeditorV2_20090713.zip

    对以下文件的指定行进行了修改,
    /FileBrowser/Config.cs line 45, 116, 169
    /FileBrowser/FileWorkerBase.cs line 68, 98, 110, 125, 278
    所有修改的地方均包含在名为 "ZhuBo's Modification" 的代码块中,也可以通过搜索整个项目中的 "ZhuBo's Modification" 快速看到改动的地方,方便自己的扩展(比如可以设定图片的最大高度)
    更新 at 2008-11-11
    新增可选的根据用户标识让不同用户使用独自的图片上传子目录,参见上文中“三、自定义文件上传的子目录的格式”的更新部分。

    新的源码与dll文件也已更新。

    更新 at 2009-07-06
    感谢新手中的新手的发现,修正了以下Bug:未配置FCKeditor:FolderPattern,或者FCKeditor:FolderPattern为空时,上传图片成功后的路径中多了一个"/"

    更新 at 2009-07-13
    图片后缀名为.gif的不做压缩处理,防止动画效果丢失。

    您可能感兴趣的文章:
    • 手把手教你 CKEDITOR 4 扩展插件制作
    • FCKeditor 插件开发 示例(详细版本)
    • ckeditor自定义插件使用方法详解
    • CKEditor 附插入代码的插件
    • 添加FCKeditor插件需要注意的地方
    • fckeditor 修改记录添加行距功能插件
    • ckeditor插件开发简单实例
    • fckeditor 插件实例 制作步骤
    • fckeditor 插件开发参考文档
    • CKEditor中加入syntaxhighlighter代码高亮插件
    • CKEDITOR二次开发之插件开发方法
    • CKEditor扩展插件:自动排版功能autoformat插件实现方法详解
    上一篇:ckeditor syntaxhighlighter代码高亮插件,完美修复
    下一篇:FCKeditor 图片上传进度条不动的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    FCKeditor .NET的配置、扩展与安全性经验交流 FCKeditor,.NET,的,配置,扩展,