如何使fckeditor上传的文件名称前面不带路径,fckeditor的版本是2.6.3,语言是asp.net(c#)。

JavaScript016

如何使fckeditor上传的文件名称前面不带路径,fckeditor的版本是2.6.3,语言是asp.net(c#)。,第1张

假设登录用户操作,session存有用户id

打开 ~\fckeditor\fckconfig.js 文件,找到配置行

TypeConfig[ "Image" ].AllowedExtensions = new string[] { "bmp", "gif", "jpeg",

"jpg", "png" }

TypeConfig[ "Image" ].DeniedExtensions= new string[] { }

TypeConfig["Image"].FilesPath = "%UserFilesPath%image/"

TypeConfig["Image"].FilesAbsolutePath = (UserFilesAbsolutePath == "" ? "" : "%

UserFilesAbsolutePath%"image/")//文件读取文件夹

TypeConfig["Image"].QuickUploadPath = "%UserFilesPath%image/"

TypeConfig["Image"].QuickUploadAbsolutePath = (UserFilesAbsolutePath == "" ? "" :

"%UserFilesAbsolutePath%image/")//图片上传文件夹

将其修改为

TypeConfig[ "Image" ].AllowedExtensions = new string[] { "bmp", "gif", "jpeg",

"jpg", "png" }

TypeConfig[ "Image" ].DeniedExtensions= new string[] { }

TypeConfig["Image"].FilesPath = "%UserFilesPath%" + Session["UserID"].ToString() +

"image/"

TypeConfig["Image"].FilesAbsolutePath = (UserFilesAbsolutePath == "" ? "" : "%

UserFilesAbsolutePath%" + Session["UserID"].ToString() + "image/")

TypeConfig["Image"].QuickUploadPath = "%UserFilesPath%" + Session

["UserID"].ToString() + "image/"

TypeConfig["Image"].QuickUploadAbsolutePath = (UserFilesAbsolutePath == "" ? "" :

"%UserFilesAbsolutePath%" + Session["UserID"].ToString() + "image/")

以用户名+image为文件加名称建立文件夹,这样可以根据不同的用户显示和上载图片到不同的

文件夹中

FCKEditor于2009年被更名为新一代的CKEditor和CKFinder,见http://ckeditor.com/。只是本

来是一个的产品 (FCKEditor)现在变成了两个(CKEditor + CKFinder),如果要上传文件到

服务器上,最新版本的CKEditor + CKFinder要结合使用才能提供编辑界面及搜索文件界面,所

以还是暂时用老版本的FCKEditor吧,老版本经过这么多年的历练,稳定性应该没得说 了。

知道FCKEditor的,就不能算是菜鸟了,所以这里也不多谈它是个什么东东,也不多谈它 与其

它在线html编辑器的对比(有时间的话,发一个适合于ASP.NET环境的主流在线html编辑器对比

的博客,不过现在请相信:FCKEditor 这个当前名列第一的在线html编辑器的确是货真价实。

下边,详细地说明FCKEditor在ASP.NET环境下的配置,并如何设定它可以上传文 件。注意,请

严格按照说明配置,代码可以复制完成,如果你在看完本博客还是完成不了FCKEditor的配置,

请在下边评论中留言,说明情况,博主帮助你 解决,甚至可以把博主自己配置好的环境给你发

到邮箱里(当然,你要在这个博客纸条里提供你的邮箱)。当然还是建议自己配置好,因为用

这个工具的都是网站开 发人员,如果按说明连这个都拿不下来,何谈开发?

笔者使用的环境是XP3、SQL SERVER EXPRESS 2008、VS2008(C#),注意它同样适用VS2005及

Visual Web Developer这些环境,只要是.NET FRAMEWORK 2.0以上即可

注,fckeditor2.6有错误,源码需要修改

1、FCKEditor版本

当前FCKEditor的最新版本是FCKEditor2.6.5,笔者没有采用最新的 CKEditor + CKFinder组合

2、FCKEditor下载

到http://ckeditor.com/download下 载,下载两个压缩文件,分别是FCKeditor_2.6.5.zip 和

FCKeditor.Net 2.6.3.zip,注意不要下载网页最上边的那个CKEditor 3.1文件,本博文不用这

个版本。

FCKeditor_2.6.5.zip是FCKEditor的页面运行文 件,FCKeditor.Net 2.6.3.zip是为ASP.NET环

境制作的一个控件,最重要的就是里边那个.dll文件(后边会谈到)

3、FCKEditor解压及安装

最好新建一个网站进行配置,完成后,再对已经建成的ASP.NET网站配置,比如测试本博文 的

工作情况,笔者建立了一个网站,目录为F:\web。解压FCKeditor_2.6.5.zip 至网站根目录下

的fckeditor中,比如笔者的网站根目录是F:\web,则将这个压缩文件解压到

F:\web\fckeditor 内(注意实际解压时,会是像这样的目录 FCKeditor_2.6.5\fckeditor,把

fckeditor这个目录复制到网站根目录下即可);解压另外一个压缩文件 FCKeditor.Net

2.6.3.zip 到任意目录,注意把目录FCKeditor.Net 2.6.3\bin\Release\2.0 下的文件(只有

这一个文件)FredCK.FCKeditorV2.dll 复制到网站根目录下的 \bin\ 目录内,按笔者的网站

,就应该是 F:\web\bin 内。如果你这个网站是刚刚建立的网站,bin目录可能不存在,手工建

立一个即可,注意保证目录名拼写正确。这个 .dll 文件是专门为asp.net 制作的一个控件。

在VS2008右边解决方案资源管理器内点击“刷新”工具按钮(右边数第2个),保证在根目录下

的 bin 目录内可以看到刚才复制的 .dll 文件。

4、建立FCKEditor控件

在VS2008左边工具箱内右击,点击快捷菜单中的“选择项...”,在“选择工具箱项”对 话框

中,点击“浏览”按钮,找到第3步你复制到 bin 目录内的 .dll 文件,点击“打开”,再点

击“确定”;再看工具箱最下部的“常规”选项卡下,新添加了一个FCKEditor控件,添加成功

。注意现在不要往网页上拖放, 因为还没有配置好,即使把它拖放上去,也不能用。

5、在VS2008环境中进入fckeditor目录,打开fckconfig.js文 件,找到两行代码:

var _FileBrowserLanguage = 'asp' // asp | aspx | cfm | lasso | perl | php | py

var _QuickUploadLanguage = 'asp' // asp | aspx | cfm | lasso | perl | php | py

将它们改成:

var _FileBrowserLanguage = 'aspx' // asp | aspx | cfm | lasso | perl | php | py

var _QuickUploadLanguage = 'aspx' // asp | aspx | cfm | lasso | perl | php | py

可以看出这个里边有许多语言的选项,默认的是asp, 我们现在已经改成了aspx(红色是要改的

地方)

6、在网站根目录下建立一个 Test.aspx 网页,复制下边一行代码

<%@ Register TagPrefix="FCKeditorV2" Namespace="FredCK.FCKeditorV2"

Assembly="FredCK.FCKeditorV2" %>

把它粘贴到Test.aspx页面源代码 <%@ Page Language="C#" ... 那一行下边(就是粘贴到第二

行);

然后再复制下边四行代码

<form id="Form1" method="post" runat="server">

<FCKeditorV2:FCKeditor id="content" runat="server" BasePath="~/fckeditor/">

</FCKeditorV2:FCKeditor>

</form>

选定<body></body>内的全部内容(不含这对起始终止标签),然后粘贴(实际上是替换

<body>...</body>内 的全部内容)

Well done! 现在可以了,运行之前把这个Test.aspx设为起始页,以后测试方便。Crtl + F5

运行,你可以看到浏览器内已经出现如下图所示的FCKEditor编辑界面:

点击第二行的“插入/编辑图片”按钮,出来一个对话框,点击上传标签,如下图所示:

再点击“浏览”按钮,出来就是你熟悉的选择文件对话框,选定相应的图片,点击“打开”,

回到 上图的界面,再点击“发送到服务器上”......??????

出现错误信息了吧,说无法复制。实际上,前述的6个步骤也就是做到这里:把界面显示出来,

点 击“插入/编辑图片”按钮,可以出来对话框,也可以查找文件,但发送到服务器上会失败

前边的步骤让我们看到了希望。下边的步骤我们再耐心做下去,让发送到服务器上成功!

7、配置web.config

在WEB页面使用 FCKEditor 时,页面需要知道到哪里去找这个编辑器。现在进入 web.config

文件进行配置。打开 web.config,在appSettings配置节中加入(注意:如果是刚刚建立的网

站,这个配置节的样子应该 是<appSettings/>,需要把它做成起始与结束标签,像这样

<appSettings> </appSettings>,然后再向里边加入下边这行代码):

<add key="FCKeditor:BasePath" value="~/fckeditor/" />

在这里配置好以后,今天加入FCKEditor编辑器控件时,就不用再设定BasePath 值;

用户上传文件的缺省目录是网站根目录下的 UserFiles 目录,如果想要更改,同样要在

appSettings配置节中设定,将下边这一行

<add key="FCKeditor:UserFilesPath" value="~/wusir/" />

加入到刚才加入的那一行下面,今后上传到服务器的文件,就会放到网站根目录下的 wusir 目

录内。本步骤完成后,下边的代码应该出现在 web.config 文件中(刚才完成的工作):

<appSettings>

<!--设定寻找fckeditor路径及设定上传文件保存路径-->

<add key="FCKeditor:BasePath" value="~/fckeditor/" />

<add key="FCKeditor:UserFilesPath" value="~/wusir/" />

</appSettings>

要说明的是,在实际应用中,用户上传文件目录最好不是固定的,一个目录中文件太多,会影

响 访问速度,所以用户上传文件的目录,实际应用开发中,建议在代码中每隔一段时间自动建

一个新目录,比如按年份 + 月份 建目录。

8、启用文件上传功能

FCKeditor提供了强大和易用的文件上传功能,但是缺省配置中,文件上传功能不可用, 这是

基于安全的考虑。我们现在来修改它,使它可以完成上传功能。至于这个编辑器是在后台使用

还是前台使用,用到什么权限,由网站开发人员用程序来设定吧。

在VS2008中打开 ~\fckeditor\editor\filemanager\connectors\aspx\config.ascx 文件(~在

ASP.NET中表示网站根目录),找到 CheckAuthentication(),将其中唯一的一行语句:

return false

改作:

return true

即不经过身份验证,任何人都可以上传文件,修改完成后,关闭并保存这个文件;

假设登录用户操作,session存有用户id

打开 ~\fckeditor\fckconfig.js 文件,找到配置行

TypeConfig[ "Image" ].AllowedExtensions = new string[] { "bmp", "gif", "jpeg",

"jpg", "png" }

TypeConfig[ "Image" ].DeniedExtensions= new string[] { }

TypeConfig["Image"].FilesPath = "%UserFilesPath%image/"

TypeConfig["Image"].FilesAbsolutePath = (UserFilesAbsolutePath == "" ? "" : "%

UserFilesAbsolutePath%"image/")//文件读取文件夹

TypeConfig["Image"].QuickUploadPath = "%UserFilesPath%image/"

TypeConfig["Image"].QuickUploadAbsolutePath = (UserFilesAbsolutePath == "" ? "" :

"%UserFilesAbsolutePath%image/")//图片上传文件夹

将其修改为

TypeConfig[ "Image" ].AllowedExtensions = new string[] { "bmp", "gif", "jpeg",

"jpg", "png" }

TypeConfig[ "Image" ].DeniedExtensions= new string[] { }

TypeConfig["Image"].FilesPath = "%UserFilesPath%" + Session["UserID"].ToString() +

"image/"

TypeConfig["Image"].FilesAbsolutePath = (UserFilesAbsolutePath == "" ? "" : "%

UserFilesAbsolutePath%" + Session["UserID"].ToString() + "image/")

TypeConfig["Image"].QuickUploadPath = "%UserFilesPath%" + Session

["UserID"].ToString() + "image/"

TypeConfig["Image"].QuickUploadAbsolutePath = (UserFilesAbsolutePath == "" ? "" :

"%UserFilesAbsolutePath%" + Session["UserID"].ToString() + "image/")

以用户名+image为文件加名称建立文件夹,这样可以根据不同的用户显示和上载图片到不同的

文件夹中

找到另外一个配置行

FCKConfig.LinkBrowserURL = FCKConfig.BasePath +

'filemanager/browser/default/browser.html?Connector=' + encodeURIComponent(

FCKConfig.BasePath + 'filemanager/connectors/' + _FileBrowserLanguage +

'/connector.' + _FileBrowserExtension )

将其修改为(红色部分为添加内容):

FCKConfig.LinkBrowserURL = FCKConfig.BasePath +

'filemanager/browser/default/browser.html?Type=File&Connector=' +

encodeURIComponent( FCKConfig.BasePath + 'filemanager/connectors/' +

_FileBrowserLanguage + '/connector.' + _FileBrowserExtension )

找到另外一个配置行

FCKConfig.LinkUploadURL = FCKConfig.BasePath + 'filemanager/connectors/' +

_QuickUploadLanguage + '/upload.' + _QuickUploadExtension

将其修改为(红色部分为添加内容):

FCKConfig.LinkUploadURL = FCKConfig.BasePath + 'filemanager/connectors/' +

_QuickUploadLanguage + '/upload.' + _QuickUploadExtension + '?Type=File'

修改完成后,关闭并保存文件。

从这个配置文件来看,有三种类型,分别是 File, Image, Flash,后两种都在配置文件中显式

指定,Type=File 没有指定,应该是缺省的配置,但如果不显式配置,会出现问题,所以在这

里显式配置出来。

点击VS2008菜单中的“生成 >生成网站”,然后点击“调试 >开始执行(不调试)”,重复前述

的插入图片的做法,最后点击“发送到服务器上”,

Congratulations!!!

一鼓作气看到这里,估计读者累得够呛了吧。可以放松一下了,因为主要工作已经完成了。下

边的 工作是零碎的细化工作,心态就更放松了。

9、人性化、中文化FCKEditor

在解决方案资源管理器中打开 ~\fckeditor\fckconfig.js 文件

配置控件语言:

找到下面的配置行

FCKConfig.AutoDetectLanguage = true

FCKConfig.DefaultLanguage = 'en'

将其改为(红字部分):

FCKConfig.AutoDetectLanguage = true

FCKConfig.DefaultLanguage = 'zh-cn'

即采用简体中文作为缺省语言。细心的读者已经看到,这里只改了一行,而笔者是写出了两行

,实 际上是想说明一个问题,可能更细心的读者已经看到本博文的第一个图片(就是

FCKEditor编辑界面),它已经是中文了,这里边即使改成红颜色的简体中 文,再运行还是一

样的。注意这里没有改的第一行,这一行是自动检测语言,它会自动按浏览器的语言设定

FCKEditor自己的显示语言的,所以即使第二行 缺省语言在修改前是英语,但实际显示出来的

仍然是中文,因为它检测出我的浏览器是中文的。妙吧!

配置 Tab 键:

默认 Tab 键在FCKeditor中不可用,找到配置行

FCKConfig.TabSpaces = 0

将其修改为(红字部分):

FCKConfig.TabSpaces = 4

也就是改成了,按一下 Tab 键,缩进4个格,和VS2008编辑器的缩进是一样的,如果你想改成

其它的值,比如3,比如5,你自己看着改吧。

为FCKEditor换肤:

FCKEditor提供了三个换肤方案:default, office2003和silver。

找到配置行

FCKConfig.SkinPath = FCKConfig.BasePath + 'skins/default/'

可以看出现在配置的是缺省的外观(本博文截图就是这种外观),如果想尝试其它两种外观,

可以 分别改作:

FCKConfig.SkinPath = FCKConfig.BasePath + 'skins/office2003/'

或者

FCKConfig.SkinPath = FCKConfig.BasePath + 'skins/silver/'

保存以后,运行一下,看看喜欢哪一种。

定制工具栏按钮:

本博文第一张图片是一个全功能的按钮配置,在实际应用中,如果后台使用FCKEditor, 还可

以用它,如果是前台使用,比如论坛、回帖等等,这种配置就易造成安全性问题。这个工具栏

按钮可以手工配置的。

在 fckconfig.js 中提供两种工具栏配置。在配置行

FCKConfig.ToolbarSets["Default"] = [ ... ]

里定义了使用全部可用按钮的配置(作为工具栏的默认配置)。

在配置行

FCKConfig.ToolbarSets["Basic"] = [ ... ]

中定义了一个精简按钮的工具栏配置。如果对这两个都不满意,修改定制自己的按钮集好了。

配置值[ ... ]中是形式为[[v, v2, .., vN], '/', [ ... ],...](vN表示要显示的按钮名字

,'/'表示之后的按钮组在下一行显示)的按钮分组的集合。如果不需要整个分组的按钮,那么

就删掉该分组(形式为 [ , , ...]);如果只是不需要分组中的某个按钮,删掉该按钮。

注意在修改时,把

FCKConfig.ToolbarSets["Default"] = [ ... ]

全部内容复制粘贴在下边一份,把其中一份注释掉,修改另外一份,删除的方法比添加的方法

好, 这样安全,规范。修改时,随时运行网页,查看实际效果。

添加常用中文字体:

找到配置行

FCKConfig.FontNames = 'ArialComic Sans MSCourier NewTahomaTimes New

RomanVerdana'

将其修改为(红色为添加部分):

FCKConfig.FontNames = '宋体黑体隶书楷体_GB2312ArialComic Sans MSCourier

NewTahomaTimes New RomanVerdana'

关闭fckconfig.js,点击“生成 >生成网站”,运行,看看修正后的效果。

10、FCKEditor瘦身

如果前边进展一切顺利,把这个网站目录复制存留一份复件,然后开始进行瘦身。

因为FCKEditor是针对所有主流的WEB开发平台,又针对所有主要国家语言的软件,而 我们现在

只用它运行于中文(把英文也考虑进去吧),只运行于ASP.NET平台,所以我们把其它与此无关

的内容删除。

首先,在 ~\fckeditor 目录下,把所有以“_”符号形状的目录及文件全部删除,这样在

~\fckeditor 下只有一个 editor 目录;

其次,在 ~\fckeditor 目录下,只保留 fckconfig.js、fckeditor.asp、fckeditor.js、

fckstyles.xml、fcktemplates.xml 这五个文件,其它一律删除,如笔者的解决方案资源管理

器截图如下:

接着,进入 ~\fckeditor\editor 目录,删除其中的 _source 目录;

进入 ~\fckeditor\editor\lang 目录,只留下 en.js, zh-c

n.js 和 zh.js 这三个文件,其它文件全部删除,这些是工具栏语言文件,留下的三个分别是

英语、简体汉字和繁体汉字。

进入 ~\fckeditor\editor\filemanager\connectors 目录,这里有支持各个开发平台的目录,

只留下 aspx 目录,其它目录一概删除,注意留下那两个文件吧。

好了,大功告成!

看累了吧,我写得更累,愿这篇博文能够帮助你解决配置 FCKEditor

如何解决上传文件的中文乱码问题? 答案如下:

首先要知道,一般软件公司的编码形式是gb2312

因为我的fck在单独的一个目录所以在上传文件的时候可以自定义一个编码形式

即在fck目录下加一个web.config文件,指定其编码格式为utf-8

FCKeditor补充知识:如何设置Fckeditor为只读文本呢?

首先在fckConfig.js文件中加如一个toobarSet的配置 ,如下 :

FCKConfig.ToolbarSets["Readonly"] = [

['Preview', 'Print']

]

然后在Fckeditor所在页面加入如下js脚本,大功告成了

<script language="javascript" type="text/javascript">

function FCKeditor_OnComplete(editor) {

editor.EditorDocument.body.contentEditable = false

editor.EditMode = FCK_EDITMODE_SOURCE

editor.ToolbarSet.RefreshModeState()

editor.EditMode = FCK_EDITMODE_WYSIWYG

editor.ToolbarSet.RefreshModeState()

}

</script>

可是问题又出来了,我原先在一个页面适用一个Fckeditor,控制其是否只读,按上面的做没错

误,但是如今我有两个或以上的Fckeditor在同一个页面中,并且不都设置为只读,怎么办?

没关系,又解决办法地:

js在客户端有浏览器执行,而asp.net应用程序运行在服务器端。

删除一条微博是由页面提交表单,由服务器上的asp.net应用程序,对数据库进行操作,再对客户端页面进行刷新。可以不需要JS。

JS通常用来做一些客户端特效。而数据处理主要由asp.net应用程序完成。

做asp.net页面时,VS也会自动加入一些JS。