1. 原先的配置
把 fckeditor/filemanager/connectors 目錄刪除;
有同學可能會問了,都刪除了怎么上傳文件?
呵呵。。。
2. 不要引用 FredCK.FCKeditorV2.dll;
因為我都是采用js寫的,不采用控件的方式;
其實網上有很多人在嘗試往 fckeditor/filemanager/connectors目錄下注入,
確實也有人不小心直接把FCK編輯器沒有任何配置的情況下傳到網上導致中招了;
3. 現在講正題吧,一般來說我們用FCK的時候并不多,在一個系統里面可能也就幾個地方
現在假如我有一個簡單的系統,里面有“新聞”發布和,類似“公司簡介”單頁發布兩個地方要用的FCK
我要把所有文章的圖片放到 /Article/yyyyMMdd/guid.jpg
把所有單頁的圖片放到 /Page/yyyyMMdd/guid.jpg
或者說我要把圖片按用戶存到不同的地方。。。
4.實現
怎么很簡單的事情要說清楚需要做這么多鋪墊,太麻煩了。。。。?。?!
web頁面:
代碼
復制代碼 代碼如下:
form id="form1" runat="server">
div>
div>
asp:TextBox ID="TextBox1" TextMode="MultiLine" runat="server"> /asp:TextBox>
/div>
br />
asp:Button ID="Button1" runat="server" Text="Button" onclick="Button1_Click" />
/div>
/form>
JS:
代碼
復制代碼 代碼如下:
script src="fckeditor/fckeditor.js" type="text/javascript">/script>
script type="text/javascript">
window.onload = function() {
var oFCKeditor = new FCKeditor('%= TextBox1.ClientID %>');
oFCKeditor.BasePath = 'fckeditor/'
oFCKeditor.Config.ImageUploadURL = "/admin/auploader.aspx";
oFCKeditor.ReplaceTextarea();
}
/script>
這樣就搞定了!
不要不相信啊,下面把上傳頁面的代碼簡單的寫一個吧,對這個也比較重要;
代碼
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
if (Request.Files.Count > 0)
{
HttpPostedFile file = Request.Files[0];
string path = "/Article/" + System.DateTime.Now.ToString("yyyyMMdd") + "/";
string serverPath = Server.MapPath(path);
string fileName = Guid.NewGuid() + file.FileName.Substring(file.FileName.LastIndexOf("."));
if (!System.IO.Directory.Exists(serverPath))
System.IO.Directory.CreateDirectory(serverPath);
file.SaveAs(serverPath + fileName);
SendFileUploadResponse(0, path + fileName, fileName, "上傳成功!");
}
else
{
SendFileUploadResponse(1, "", "", "上傳失??!");
}
}
public void SendFileUploadResponse(int isSucceed, string fileUrl, string fileName, string customMsg)
{
System.Web.HttpContext.Current.Response.Clear();
System.Web.HttpContext.Current.Response.Write("script type='text/javascript'>");
System.Web.HttpContext.Current.Response.Write(@"(function(){var d=document.domain;while (true){try{var A=window.top.opener.document.domain;break;}catch(e) {};d=d.replace(/.*?(?:\.|$)/,'');if (d.length==0) break;try{document.domain=d;}catch (e){break;}}})();");
System.Web.HttpContext.Current.Response.Write("window.parent.OnUploadCompleted(" + isSucceed.ToString().ToLower() + ", '" + fileUrl + "', '" + fileName + "', '" + customMsg + "');");
System.Web.HttpContext.Current.Response.Write("/script>");
System.Web.HttpContext.Current.Response.End();
}
好了搞定了!
這個上傳代碼沒有做嚴格的后綴限制,大小限制;因為這個頁面路徑是我們自己配置的嘛,想怎么寫就怎么寫了;
甚至你可以根據不同的用戶存到不同的地方;
這里需要說明一下 SendFileUploadResponse 方法,其實就是為FCk傳回消息;
這里:
System.Web.HttpContext.Current.Response.Write("window.parent.OnUploadCompleted(" + isSucceed.ToString().ToLower() + ", '" + fileUrl + "', '" + fileName + "', '" + customMsg + "');");
對應的是
fckeditor/dialog/fck_image/fck_image.js
代碼
復制代碼 代碼如下:
function OnUploadCompleted( errorNumber, fileUrl, fileName, customMsg )
{
// Remove animation
window.parent.Throbber.Hide() ;
GetE( 'divUpload' ).style.display = '' ;
switch ( errorNumber )
{
case 0 : // No errors
alert( 'Your file has been successfully uploaded' ) ;
break ;
case 1 : // Custom error
alert( customMsg ) ;
return ;
case 101 : // Custom warning
alert( customMsg ) ;
break ;
case 201 :
alert( 'A file with the same name is already available. The uploaded file has been renamed to "' + fileName + '"' ) ;
break ;
case 202 :
alert( 'Invalid file type' ) ;
return ;
case 203 :
alert( "Security error. You probably don't have enough permissions to upload. Please check your server." ) ;
return ;
case 500 :
alert( 'The connector is disabled' ) ;
break ;
default :
alert( 'Error on file upload. Error number: ' + errorNumber ) ;
return ;
}
sActualBrowser = '' ;
SetUrl( fileUrl ) ;
GetE('frmUpload').reset() ;
}
注意到 0 ,是成功,1 是失敗,其他的自己看吧。。。。
對了說明一下這里用的是 2.65 版本測試的,如果有其他版本不一樣的靈活變通下哈;
總結一下:
1. 在不同的頁面配置不同的圖片處理路徑,如:
oFCKeditor.Config.ImageUploadURL = "/admin/aupload.aspx";
oFCKeditor.Config.ImageUploadURL = "/admin/bupload.aspx";
。。。。
2. FCk 會把圖片post到指定的路徑,
然后你自己操作圖片,按目錄存啊還是按當前用戶session存隨便來;
當然別忘記驗證用戶的身份在先,沒有權限的不要對他客氣,直接返回錯誤,
驗證身份示例代碼里面沒寫,自己根據項目自己加吧
3. 一定要返回值告訴FCK你的操作結果,否則會一直死在那里的。。。
PS:
看來我不是個喜歡寫東西的人,覺得很麻煩。。。
您可能感興趣的文章:- asp.net+FCKeditor上傳圖片顯示叉叉圖片無法顯示的問題的解決方法
- 修改fckeditor的文件上傳功能步驟
- 整合ckeditor+ckfinder,解決上傳文件路徑問題
- 通過Fckeditor把圖片上傳到獨立圖片服務器的方法
- FCKeditor編輯器添加圖片上傳功能及圖片路徑問題解決方法
- 為ckeditor編輯器加上傳圖片的功能
- Asp.net FCKEditor 2.6.3 上傳文件沒有權限解決方法
- FCKeditor ASP.NET 上傳附件研究
- asp fckeditor自定義上傳文件的文件名
- CKEditor與dotnetcore實現圖片上傳功能