亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

HTML編輯器FCKeditor .NET的配置、擴展與安全性經驗交流

2024-07-21 02:53:55
字體:
來源:轉載
供稿:網友
FCKeditor是使用非常廣泛的HTML編輯器,本文從 ASP.NET 的使用場景對 FCKeditor 與 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是相對路徑,如圖: 
HTML編輯器FCKeditor .NET的配置、擴展與安全性經驗交流
我增加了這個擴展,在Web.config appSettings可以配置上傳后圖片URL的域名,如: 

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

HTML編輯器FCKeditor .NET的配置、擴展與安全性經驗交流 
七、解決上傳文件名含有中文的文件時提示 "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.vevb.com/201108/yuanma/FCKeditor.Net_2.6.3_20090713.zip 
BIN(.NET 2.0): http://xiazai.vevb.com/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的不做壓縮處理,防止動畫效果丟失。


注:相關教程知識閱讀請移步到編輯器頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩av电影免费观看高清| 亚洲免费电影一区| 午夜精品久久久久久久99热| 欧美日韩亚洲网| 伊人激情综合网| 性欧美激情精品| 午夜精品福利电影| 久久综合国产精品台湾中文娱乐网| 亚洲一区二区三区成人在线视频精品| 成人激情在线播放| 成人国产精品久久久久久亚洲| 日韩69视频在线观看| 亚洲成av人乱码色午夜| 欧美性黄网官网| 国产成人精品综合| 国产日韩精品综合网站| 久久久久这里只有精品| 国产日韩欧美夫妻视频在线观看| 91精品视频大全| 日韩一二三在线视频播| 成人网在线免费观看| 色噜噜狠狠狠综合曰曰曰| 国产一区深夜福利| 亚洲精品资源美女情侣酒店| 欧美片一区二区三区| 日韩在线观看成人| 欧美精品午夜视频| 亚洲精品久久视频| 国产中文日韩欧美| 国产精品欧美激情| 国产成人精品久久| 91亚洲va在线va天堂va国| 精品日韩中文字幕| 亚洲天堂影视av| 日本久久亚洲电影| 色偷偷91综合久久噜噜| 国产成人精品最新| 国产欧美精品日韩精品| 久久亚洲国产成人| 日本一区二三区好的精华液| 日韩一区二区精品视频| 国产在线999| 秋霞成人午夜鲁丝一区二区三区| 亚洲影视九九影院在线观看| 91精品国产高清久久久久久久久| 国产精品第8页| 亚洲女人被黑人巨大进入| 97久久精品人人澡人人爽缅北| 亚洲国产精品久久久久久| 国产精品偷伦一区二区| 久久久女女女女999久久| 国产一区二区av| 国产精品久久av| 91九色国产社区在线观看| 久久久久久成人| 国产精品一区电影| 一个人www欧美| 91在线|亚洲| 97在线观看视频国产| 亚洲国产成人精品一区二区| 精品福利樱桃av导航| 国产精品久久久久免费a∨大胸| 午夜精品免费视频| 一夜七次郎国产精品亚洲| 日韩成人激情视频| 国产一区二区三区欧美| 精品久久久久久亚洲国产300| 亚洲跨种族黑人xxx| 国产精品永久免费| 欧美亚洲国产日本| 97av在线影院| 欧美午夜丰满在线18影院| 亚洲欧美精品一区二区| 91中文字幕在线观看| 中文字幕日韩av| 国模精品视频一区二区三区| 国产亚洲精品久久久久动| 国产日韩换脸av一区在线观看| 亚洲第一福利在线观看| 欧美日韩国内自拍| 国产精品99久久久久久www| 国产精品自产拍在线观看| 久久久久久久久久久亚洲| 久久亚洲精品毛片| 日韩在线中文字| 日韩国产激情在线| 蜜臀久久99精品久久久无需会员| 国产精品久久久久久久天堂| 精品久久久免费| 精品国产一区二区三区久久久| 精品久久久久久中文字幕一区奶水| 热99久久精品| 久久国产视频网站| 国产精品中文字幕久久久| 国产精品美女免费看| 国产久一一精品| 爱福利视频一区| 久久久久久久激情视频| 亚州欧美日韩中文视频| 亚洲欧美一区二区三区在线| 国产视频精品一区二区三区| 中文字幕亚洲欧美| 成人在线国产精品| 青青久久av北条麻妃黑人| 日韩电影中文字幕av| 亚洲人成77777在线观看网| 欧美日韩国产一区二区三区| 亚洲男人天堂2024| 亚洲自拍偷拍福利| 日韩av免费在线播放| 久久精品2019中文字幕| 一区二区三区视频观看| 中文字幕v亚洲ⅴv天堂| 国产一区二区动漫| 91国产精品视频在线| 668精品在线视频| 欧美小视频在线| 51精品在线观看| 亚洲奶大毛多的老太婆| 久久成人一区二区| 亚洲综合色av| 日韩av在线网址| 亚洲一区二区三区四区视频| 2019亚洲日韩新视频| 欧美激情18p| 亚洲网在线观看| 国产精品三级网站| 亚洲影院在线看| 日韩电影中文 亚洲精品乱码| 92看片淫黄大片欧美看国产片| 26uuu日韩精品一区二区| 搡老女人一区二区三区视频tv| 136fldh精品导航福利| 国产亚洲激情在线| 国产精品第一第二| 国产91露脸中文字幕在线| 亚洲91精品在线| 国产欧美精品一区二区三区-老狼| 91国产精品91| 日本久久久久久| 国内精品中文字幕| 亚洲大胆美女视频| 色婷婷av一区二区三区久久| 51ⅴ精品国产91久久久久久| 欧美性理论片在线观看片免费| 亚洲日本欧美日韩高观看| 欧美肥婆姓交大片| 九九热最新视频//这里只有精品| 91国产精品视频在线| 国产成人亚洲综合91精品| 亚洲国产精品人久久电影| 国产99久久精品一区二区永久免费| 国产98色在线| 久久久久女教师免费一区| www国产亚洲精品久久网站| 欧美精品videosex性欧美| 欧美电影在线播放| 尤物99国产成人精品视频| 亚洲电影在线看| 国产色婷婷国产综合在线理论片a| 国产精品三级在线| 日韩电影中文字幕在线观看| 欧美黑人巨大精品一区二区| 欧美性猛交丰臀xxxxx网站|