kindeditor-4.1.10 结合 Asp.Net MVC 添加图片功能
KindEditor是一套开源的HTML可视化编辑器,现在我要结合Asp.Net MVC4 上传图片功能,做相应的配置和修改,
其实网上也有人写过类似的文章了,我写出来是以防以后使用的时候出现这样的问题,所以收集起来做参考之用,
如果有人遇到这样的问题,可以和我一起交流,qq号在我博客上已经贴出来了。
下面就开始贴出我的源代码:
js:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | var keditor; var koption = { allowFileManager: true , //是否可以浏览上传文件 allowUpload: true , //是否可以上传 fileManagerJson: '/KindEditor/ProcessRequest' , //浏览文件方法 uploadJson: '/KindEditor/UploadImage' //上传文件方法(注意这两个路径) }; KindEditor.ready( function (k) { keditor = k.create( '#content-js' , koption); prettyPrint(); }); function btn_submit() { var lables = '' ; var title = $( "#txt_title" ).val(); if (title.length == 0 || keditor.isEmpty()) { alert( "标题或内容为空!" ); return false ; } $( "input[name=lable]:checked" ).each( function () { lables += $( this ).val() + ',' ; }); ; zwobj.url = "/Manage/AddArticle" ; zwobj.data = { title: title, content: encodeURI(keditor.html()), lables: lables.substr(0, lables.length - 1) }; ajaxData(); return true ; } |
aspx:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | <%@ Page Language= "C#" EnableEventValidation= "false" ValidateRequest= "false" Inherits= "System.Web.Mvc.ViewPage<dynamic>" %> <%@ Import Namespace= "MyMvc4Project.Dal.Views" %> <!DOCTYPE html> <html> <head runat= "server" > <meta name= "viewport" content= "width=device-width" /> <title>NewArticle</title> <link href= "../../Scripts/kindeditor-4.1.10/themes/default/default.css" rel= "stylesheet" type= "text/css" /> <link href= "../../Scripts/kindeditor-4.1.10/plugins/code/prettify.css" rel= "stylesheet" type= "text/css" /> <link href= "../../Scripts/Lib/Manage/Manage.css" rel= "stylesheet" type= "text/css" /> <script src= "../../Scripts/jquery/jquery-1.8.3.js" type= "text/javascript" ></script> <script src= "../../Scripts/jquery/jquery.form.js" type= "text/javascript" ></script> <script src= "../../Scripts/kindeditor-4.1.10/kindeditor-all-min.js" type= "text/javascript" ></script> <script src= "../../Scripts/kindeditor-4.1.10/lang/zh_CN.js" type= "text/javascript" ></script> <script src= "../../Scripts/kindeditor-4.1.10/plugins/code/code.js" type= "text/javascript" ></script> <script src= "../../Scripts/kindeditor-4.1.10/plugins/code/prettify.js" type= "text/javascript" ></script> <script src= "../../Scripts/zwjs.js" type= "text/javascript" ></script> <script src= "../../Scripts/Lib/Manage/NewArticle.js" type= "text/javascript" ></script> </head> <body> <div class = "kedit" > <form id= "form-article" name= "form-article" method= "POST" > <p> 标题:</p> <input type= "text" id= "txt_title" name= "title" /> <p> 正文:</p> <textarea id= "content-js" name= "content" ></textarea> <p> <% var lable = ViewData[ "lable" ] as IList<LableView>; if (lable != null && lable.Count != 0) { %> <p>标签:</p> <% foreach ( var view in lable) {%> <input class = "chk-lable" name= "lable" type= "checkbox" value= "<%= view.Name %>" ><%= view.Name %></input> <%} %> <% } else { %> <p>无标签</p> <% } %> </p> <p> <input id= "btn-submit" type= "submit" value= "发布" onclick= "btn_submit()" /> <input id= "btn-cancel" type= "button" value= "取消" /></p> </form> </div> </body> </html> |
XXXController.cs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 | using System; using System.Collections; using System.Collections.Generic; using System.Globalization; using System.IO; using System.Linq; using System.Text; using System.Text.RegularExpressions; using System.Web; using NHibernate; using System.Web.Mvc; using MyMvc4Project.Infrastructure.Helpers; using MyMvc4Project.Dal.Implementation; using MyMvc4Project.Service; namespace MyMvc4Project.Controllers { public class KindEditorController : Controller { [HttpPost] public ActionResult UploadImage() { string savePath = "/UploadImages/" ; string saveUrl = "/UploadImages/" ; string fileTypes = "gif,jpg,jpeg,png,bmp" ; int maxSize = 1000000; Hashtable hash = new Hashtable(); HttpPostedFile file = System.Web.HttpContext.Current.Request.Files[ "imgFile" ]; if (file == null ) { hash = new Hashtable(); hash[ "error" ] = 1; hash[ "message" ] = "请选择文件" ; return Json(hash, "text/html;charset=UTF-8" ); } string dirPath = System.Web.HttpContext.Current.Server.MapPath(savePath); if (!Directory.Exists(dirPath)) { hash = new Hashtable(); hash[ "error" ] = 1; hash[ "message" ] = "上传目录不存在" ; return Json(hash, "text/html;charset=UTF-8" ); } string fileName = file.FileName; string fileExt = Path.GetExtension(fileName).ToLower(); ArrayList fileTypeList = ArrayList.Adapter(fileTypes.Split( ',' )); if (file.InputStream == null || file.InputStream.Length > maxSize) { hash = new Hashtable(); hash[ "error" ] = 1; hash[ "message" ] = "上传文件大小超过限制" ; return Json(hash, "text/html;charset=UTF-8" ); } if ( string .IsNullOrEmpty(fileExt) || Array.IndexOf(fileTypes.Split( ',' ), fileExt.Substring(1).ToLower()) == -1) { hash = new Hashtable(); hash[ "error" ] = 1; hash[ "message" ] = "上传文件扩展名是不允许的扩展名" ; return Json(hash, "text/html;charset=UTF-8" ); } string newFileName = DateTime.Now.ToString( "yyyyMMddHHmmss_ffff" , DateTimeFormatInfo.InvariantInfo) + fileExt; string filePath = dirPath + newFileName; file.SaveAs(filePath); string fileUrl = saveUrl + newFileName; hash = new Hashtable(); hash[ "error" ] = 0; hash[ "url" ] = fileUrl; return Json(hash, "text/html;charset=UTF-8" ); } public ActionResult ProcessRequest() { //String aspxUrl = context.Request.Path.Substring(0, context.Request.Path.LastIndexOf("/") + 1); //根目录路径,相对路径 String rootPath = "/UploadImages/" ; //根目录URL,可以指定绝对路径, String rootUrl = "/UploadImages/" ; //图片扩展名 String fileTypes = "gif,jpg,jpeg,png,bmp" ; String currentPath = "" ; String currentUrl = "" ; String currentDirPath = "" ; String moveupDirPath = "" ; //根据path参数,设置各路径和URL String path = System.Web.HttpContext.Current.Request.QueryString[ "path" ]; path = String.IsNullOrEmpty(path) ? "" : path; if (path == "" ) { currentPath = System.Web.HttpContext.Current.Server.MapPath(rootPath); currentUrl = rootUrl; currentDirPath = "" ; moveupDirPath = "" ; } else { currentPath = System.Web.HttpContext.Current.Server.MapPath(rootPath) + path; currentUrl = rootUrl + path; currentDirPath = path; moveupDirPath = Regex.Replace(currentDirPath, @"(.*?)[^\/]+\/$" , "$1" ); } //排序形式,name or size or type String order = System.Web.HttpContext.Current.Request.QueryString[ "order" ]; order = String.IsNullOrEmpty(order) ? "" : order.ToLower(); //不允许使用..移动到上一级目录 if (Regex.IsMatch(path, @"\.\." )) { System.Web.HttpContext.Current.Response.Write( "Access is not allowed." ); System.Web.HttpContext.Current.Response.End(); } //最后一个字符不是/ if (path != "" && !path.EndsWith( "/" )) { System.Web.HttpContext.Current.Response.Write( "Parameter is not valid." ); System.Web.HttpContext.Current.Response.End(); } //目录不存在或不是目录 if (!Directory.Exists(currentPath)) { System.Web.HttpContext.Current.Response.Write( "Directory does not exist." ); System.Web.HttpContext.Current.Response.End(); } //遍历目录取得文件信息 string [] dirList = Directory.GetDirectories(currentPath); string [] fileList = Directory.GetFiles(currentPath); switch (order) { case "size" : Array.Sort(dirList, new NameSorter()); Array.Sort(fileList, new SizeSorter()); break ; case "type" : Array.Sort(dirList, new NameSorter()); Array.Sort(fileList, new TypeSorter()); break ; case "name" : default : Array.Sort(dirList, new NameSorter()); Array.Sort(fileList, new NameSorter()); break ; } Hashtable result = new Hashtable(); result[ "moveup_dir_path" ] = moveupDirPath; result[ "current_dir_path" ] = currentDirPath; result[ "current_url" ] = currentUrl; result[ "total_count" ] = dirList.Length + fileList.Length; List<Hashtable> dirFileList = new List<Hashtable>(); result[ "file_list" ] = dirFileList; for ( int i = 0; i < dirList.Length; i++) { DirectoryInfo dir = new DirectoryInfo(dirList[i]); Hashtable hash = new Hashtable(); hash[ "is_dir" ] = true ; hash[ "has_file" ] = (dir.GetFileSystemInfos().Length > 0); hash[ "filesize" ] = 0; hash[ "is_photo" ] = false ; hash[ "filetype" ] = "" ; hash[ "filename" ] = dir.Name; hash[ "datetime" ] = dir.LastWriteTime.ToString( "yyyy-MM-dd HH:mm:ss" ); dirFileList.Add(hash); } for ( int i = 0; i < fileList.Length; i++) { FileInfo file = new FileInfo(fileList[i]); Hashtable hash = new Hashtable(); hash[ "is_dir" ] = false ; hash[ "has_file" ] = false ; hash[ "filesize" ] = file.Length; hash[ "is_photo" ] = (Array.IndexOf(fileTypes.Split( ',' ), file.Extension.Substring(1).ToLower()) >= 0); hash[ "filetype" ] = file.Extension.Substring(1); hash[ "filename" ] = file.Name; hash[ "datetime" ] = file.LastWriteTime.ToString( "yyyy-MM-dd HH:mm:ss" ); dirFileList.Add(hash); } //Response.AddHeader("Content-Type", "application/json; charset=UTF-8"); //context.Response.Write(JsonMapper.ToJson(result)); //context.Response.End(); return Json(result, "text/html;charset=UTF-8" , JsonRequestBehavior.AllowGet); } public class NameSorter : IComparer { public int Compare( object x, object y) { if (x == null && y == null ) { return 0; } if (x == null ) { return -1; } if (y == null ) { return 1; } FileInfo xInfo = new FileInfo(x.ToString()); FileInfo yInfo = new FileInfo(y.ToString()); return xInfo.FullName.CompareTo(yInfo.FullName); } } public class SizeSorter : IComparer { public int Compare( object x, object y) { if (x == null && y == null ) { return 0; } if (x == null ) { return -1; } if (y == null ) { return 1; } FileInfo xInfo = new FileInfo(x.ToString()); FileInfo yInfo = new FileInfo(y.ToString()); return xInfo.Length.CompareTo(yInfo.Length); } } public class TypeSorter : IComparer { public int Compare( object x, object y) { if (x == null && y == null ) { return 0; } if (x == null ) { return -1; } if (y == null ) { return 1; } FileInfo xInfo = new FileInfo(x.ToString()); FileInfo yInfo = new FileInfo(y.ToString()); return xInfo.Extension.CompareTo(yInfo.Extension); } } } } |
总结:
要注意
var koption = {
allowFileManager: true, //是否可以浏览上传文件
allowUpload: true, //是否可以上传
fileManagerJson: '/KindEditor/ProcessRequest', //浏览文件方法
uploadJson: '/KindEditor/UploadImage'//上传文件方法(注意这两个路径)
};
的配置,尤其是fileManagerJson和uploadJson的地址写法,最后就是关于
hash = new Hashtable();
hash["success"] = true;
hash["url"] = fileUrl;
hash["msg"] = "上传成功";
return Json(hash, "text/html;charset=UTF-8");
hashtable 返回时的参数写法
如果是失败的话,当然要返回hash["error"]=1,这些你都要注意。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
2013-03-13 VS2010中水晶报表应用及实例
2013-03-13 存储过程