FCKeditor的几点修改小结

  在我的文章系统中,打算使用FCKeditor作为在线文本编辑器,在开发过程中,有几个地方需要对编辑器

  进行修改,才能满足功能设计。

  一、修改默认的上传文件名

  FCKeditor上传文件时,默认使用客户端的文件名,遇到重名文件,则自动重新命名,对于中文名称

  的文件也是如此,这样对中文支持不好的服务器和浏览器,就容易对中文文件名的编解码出现错误而导致

  乱码,因此需要将默认的文件命名方法修改为以当前日期、时间为基本要素的文件名,同时,为了避免重

  复,还要用到随机函数。在.NET中,可以用System.Redom.Next(min, max)来生成一个介于min和max之间

  的随机数,但要注意的时,System.Redom必须实例化。

  此处修改需要FCKeditor的源代码并进行重新编译,使用VS.net 2003打开工程文件,对Uploader.cs

  文件进行修改。

  首先,将第46行string sFileName = System.IO.Path.GetFileName( oFile.FileName );注释掉;

  其次,在其下方加入如下代码

  DateTime dt = DateTime.Now;

  string sFileName = dt.Year.ToString() + dt.Month.ToString() + dt.Day.ToString() +

  dt.Hour.ToString() + dt.Minute.ToString() + dt.Second.ToString() + dt.Millisecond + new

  System.Random().Next(0, 999).ToString();

  sFileName += System.IO.Path.GetExtension( oFile.FileName );

  这样,sFileName就是形如“20070510171005230010.jpg”的文件名了,并且不可能出现重复文件名

  的现象。

  按下组合快捷键Ctrl+Shift+B生成解决方案,将项目文件夹下的bin/Debug/FredCK.FCKeditorV2.dll

  组件拷贝到网站根目录下的bin目录中,即可在网站工程中进行引用了。

  二、把上传的图片动态加入编辑器所在页面的下拉列表中

  由于需要指定文章的标志图片,除了输入以外,还应该可以从下拉列表中选择已经上传的图片,这样

  ,就必须在FCKeditor上传完图片时,*纵编辑器所在页面的select,并为其加入新的option。此处的关

  键在于对静态模式网页对话框父窗口的引用,以及利用javascript加入option。

  打开FCKeditor编辑器所在目录的\editor\dialog\fck_image\fck_image.js文件,在文件上传成功的

  事件部分,加入以下代码。

  var ddl = oEditor.parent.document.Form1.ddlPicUrl;

  var opt = oEditor.parent.document.createElement("OPTION")

  opt.text = fileName;

  opt.value= fileUrl

  ddl.options.add(opt);

  其中,oEditor是FCKeditor是对网页对话框的父窗口的引用,而oEditor.parent就是对编辑器所在页

  面的引用了。

  获取这样一个列表后,就可以在文章发布页面编写相关的javascript函数,来实现预览、选择等功能