尝试上传图片到一个单独的服务器,使用的是KindeEditor 4.1.10
kindeditor上传图片原理是:
上传按钮提交到iframe,生成1个form和1个iframe,form提交到(arget)iframe
iframe的onload方法获取返回的值,然后调用配置回调方法afterUpload/afterError。
iframe的onload方法获取返回的值,然后调用配置回调方法afterUpload/afterError。
第一次尝试
页面A document.domain = "aaa.xx.com";
图片服务器B document.domain = "bbb.xx.com";
在同一个域内xx.xx.com,KindEditor图片能上传,但是没有返回信息。
第二次尝试
直接引用
<script src="http:aaa.xx.com/kindeditor/kindeditor.js" type="text/javascript"></script>
KindEditor还是能上传图片,却无法返回信息
第三次把KindEditor直接扔到了服务器A,
页面引用<script src="http:aaa.xx.com/kindeditor/kindeditor.js" type="text/javascript"></script>
并在当前页面B新建ashx,Upload上传路径为本地的ashx通过webclient通知图片服务器的ashx并返回信息
1.通过uploadJson: '/upload_json.ashx?action=News',将图片上传到本地ashx,并用webcliet通知图片服务器
HttpPostedFile imgFile = context.Request.Files["imgFile"];//KIndEditor上传的文件 //将imgFile转换成字节形式 byte[] fileByte = new byte[imgFile.InputStream.Length]; imgFile.InputStream.Read(fileByte, 0, fileByte.Length); //通过WebClient提交文件 //本地地址做测试,端口不同,实现域不同 //图片服务器 http://192.168.0.107:81/ //本地 http://192.168.0.107:80/ string pUrl = string.Format("http://192.168.0.107:81/"); string postUrl = string.Format("{0}kindeditor/asp.net/upload_json.ashx?img={1}&path={2}&action={3}", pUrl, imgFile.FileName, path, action); System.Net.WebClient webClient = new System.Net.WebClient(); //上传数据 byte[] responseArray = webClient.UploadData(postUrl, "POST", fileByte); string result = System.Text.Encoding.Default.GetString(responseArray, 0, responseArray.Length); //对返回的数据进行根据KindEditor的样式进行json解析,需要的是Newtonsoft.dll hash bk = Newtonsoft.Json.JsonConvert.DeserializeObject<hash>(result); Hashtable hash = new Hashtable(); hash["error"] = 0;
//hash["error"]=bk.error;这样竟然无效 hash["url"] = string.Format("{0}{1}", pUrl, bk.url);
图片服务器接受本地上传的二进制图片数据,并对传送过来的主体进行保存
//获得图片 System.Drawing.Image postImage = System.Drawing.Image.FromStream(context.Request.InputStream); //保存 System.Drawing.Bitmap bitmap_b = new System.Drawing.Bitmap(postImage); bitmap_b.Save(filePath);
2.由于项目临时改变,图片和项目放在同一个服务器上,又做了调整
物理路径具体化,比如
SaveURL=@"http://192.168.0.107:81";
SavePath=@"D:\项目\路径";
//String dirPath = context.Server.MapPath(savePath);//相对路径
String dirPath = savePath;//这里改为绝对路径
删除文件的时候
删除的图片是http://192.168.1.1/k/2012/1212.jmg 通过判断是否存在http://头 http://192.168.1.1/k/2012/1212.jpg转换为物理绝对路径"D:\项目/k/2012/1212.jpg 如果是外部引入的文件则返回原地址 if (strPath.ToLower().StartsWith("http://")) { if (strPath.IndexOf(ManagerUrl) >= 0) { strPath = strPath.Replace(ManagerUrl, ManagerPath); return strPath; } else { return strPath; } } }
嗯,自己整理的也很凌乱,暂时记录下,下次慢慢完善。