kindeditor扩展粘贴图片功能&修改图片上传路径并通过webapi上传图片到图片服务器

前言

kindeditor是一个非常好用的富文本编辑器,它的简单使用我就不再介绍了。 而kindeditor却对图片的处理不够理想。

本篇博文需要解决的问题有两个:

  • kindeditor扩展粘贴图片功能
  • kindeditor修改图片上传路径并通过webapi上传图片到图片服务器(支持分布式图片)

结果演示

1.扩展粘贴图片功能演示

2.修改图片上传路径演示:

我们的网站演示地址是:http://localhost:9393/

我们的图片服务器地址是:http://localhost:9394/

我们可以看到图片被直接上传到了图片服务器。同时我们可以配置图片是上传到本地还是图片服务器。

扩展方案

1.粘贴图片功能扩展

具体请参考:http://www.cnblogs.com/cztisthebest/p/5913353.html

2.修改图片上传路径并通过webapi上传图片到图片服务器功能扩展

第一步:引用LitJSON.dll

因为我使用的开发语言是C#&ASP.NET MVC。所以首先需要在项目中引用LitJSON.dll,如下图:

第二步:修改上传文件:upload_json.ashx

<%@ WebHandler Language="C#" Class="Upload" %>

/**
 * KindEditor ASP.NET
 *
 * 本ASP.NET程序是演示程序,建议不要直接在实际项目中使用。
 * 如果您确定直接使用本程序,使用之前请仔细确认相关安全设置。
 *
 */

using System;
using System.Collections;
using System.Web;
using System.IO;
using System.Globalization;
using LitJson;

public class Upload : IHttpHandler
{
    private HttpContext context;

    public void ProcessRequest(HttpContext context)
    {
        //定义允许上传的文件扩展名
        Hashtable extTable = new Hashtable();
        extTable.Add("image", "gif,jpg,jpeg,png,bmp");
        extTable.Add("flash", "swf,flv");
        extTable.Add("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb");
        extTable.Add("file", "doc,docx,xls,xlsx,ppt,htm,html,txt,zip,rar,gz,bz2");
        //最大文件大小
        int maxSize = 1000000;
        this.context = context;

        HttpPostedFile imgFile = context.Request.Files["imgFile"];
        if (imgFile == null)
        {
            showError("请选择文件。");
        }
        //文件类型
        String dirName = context.Request.QueryString["dir"];
        if (String.IsNullOrEmpty(dirName))
        {
            dirName = "image";
        }
        if (!extTable.ContainsKey(dirName))
        {
            showError("目录名不正确。");
        }
        String fileName = imgFile.FileName;
        String fileExt = Path.GetExtension(fileName).ToLower();

        if (imgFile.InputStream == null || imgFile.InputStream.Length > maxSize)
        {
            showError("上传文件大小超过限制。");
        }

        if (String.IsNullOrEmpty(fileExt) || Array.IndexOf(((String)extTable[dirName]).Split(‘,‘), fileExt.Substring(1).ToLower()) == -1)
        {
            showError("上传文件扩展名是不允许的扩展名。\n只允许" + ((String)extTable[dirName]) + "格式。");
        }
        var saveDir = context.Request["saveDir"];
        string saveDirStr = null;
        if (saveDir == null)
        {
            saveDirStr = "tmp";
        }
        else
        {
            saveDirStr = saveDir.ToString();
        }
        //是否分布式上传
        bool isDFS = false;
        var dfs = context.Request["dfs"];
        if (dfs != null && dfs.ToString() == "1")
        {
            isDFS = true;
        }
        Hashtable hash = new Hashtable();
        if (isDFS)
        {
            var imageUrl = Cloud.Utility.ConfigHelper.Images_SITE_URL;
            var client = new RestSharp.RestClient(imageUrl);//TODO api基路径
            var request = new RestSharp.RestRequest("file/upload", RestSharp.Method.POST);
            request.AlwaysMultipartFormData = true;
            request.AddHeader("dir", dirName + "/" + saveDirStr);
            request.AddHeader("imageUrl", imageUrl);
            request.AddFile("file", Cloud.Utility.StreamHelper.ConvertToBytes(imgFile.InputStream), context.Server.HtmlEncode(imgFile.FileName));

            var posttask = client.ExecutePostTaskAsync(request);
            if (posttask.Result.StatusCode == System.Net.HttpStatusCode.OK)
            {
                var url = posttask.Result.Content.Trim(new char[] { ‘[‘, ‘]‘, ‘"‘ });
                hash["url"] = url;
            }
            else
            {
                showError("分布式上传失败");
            }
        }
        else
        {
            //文件保存目录
            string savePath = "/upload/kindeditor/" + dirName + "/" + saveDirStr;
            String dirPath = context.Server.MapPath(savePath);
            if (!Directory.Exists(dirPath))
            {
                Directory.CreateDirectory(dirPath);
            }

            String newFileName = DateTime.Now.ToString("_yyyyMMddHHmmss_ffff", DateTimeFormatInfo.InvariantInfo) + fileExt;
            String filePath = dirPath + "/" + newFileName;
            imgFile.SaveAs(filePath);
            hash["url"] = savePath + "/" + newFileName;
        }
        hash["error"] = 0;
        context.Response.AddHeader("Content-Type", "text/html; charset=UTF-8");
        context.Response.Write(JsonMapper.ToJson(hash));
        context.Response.End();
    }

    private void showError(string message)
    {
        Hashtable hash = new Hashtable();
        hash["error"] = 1;
        hash["message"] = message;
        context.Response.AddHeader("Content-Type", "text/html; charset=UTF-8");
        context.Response.Write(JsonMapper.ToJson(hash));
        context.Response.End();
    }

    public bool IsReusable
    {
        get
        {
            return true;
        }
    }
}

全部代码

客户端传过来一个文件保存目录的参数:saveDir

客户端传过来一个是否上传文件到图片服务器的参数:dfs,如果dfs=1代表上传到图片服务器,否则上传到本地

上传文件的核心代码:其中使用到了一个开源的上传组件RestSharp

第三步:webapi图片服务器端代码:

 [Route("file/upload")]
        [HttpPost]
        public async Task<HttpResponseMessage> PostFormData()
        {

            // Check if the request contains multipart/form-data.
            if (!Request.Content.IsMimeMultipartContent())
            {
                throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
            }
            var dir = Request.Headers.GetValues("dir").First();
            var imageUrl = Request.Headers.GetValues("imageUrl").First();

            string root = System.Web.HttpContext.Current.Server.MapPath(Path.Combine("~/images/", dir));

            if (System.IO.Directory.Exists(root) == false)
            {
                System.IO.Directory.CreateDirectory(root);
            }

            var provider = new MultipartFormDataStreamProvider(root);
            provider = new RenamingMultipartFormDataStreamProvider(root);//重命名写法

            await Request.Content.ReadAsMultipartAsync(provider);

            var urlList = new List<string>();
            var url = "";
            foreach (MultipartFileData file in provider.FileData)
            {
                string path = file.LocalFileName;
                var start = path.IndexOf("\\images");
                path = path.Substring(start);
                var mainURL = imageUrl;// ConfigurationManager.AppSettings["MainImageURL"];
                url = mainURL + path.Replace("\\", "/");
                urlList.Add(url);
                //return Request.CreateResponse(HttpStatusCode.OK, url);
            }

            return Request.CreateResponse(HttpStatusCode.OK, urlList);

        }

其中文件重命名方法为:

  /// <summary>
    /// 文件上传并重命名
    /// </summary>
    public class RenamingMultipartFormDataStreamProvider : MultipartFormDataStreamProvider
    {
        public string Root { get; set; }

        public RenamingMultipartFormDataStreamProvider(string root)
            : base(root)
        {
            Root = root;
        }

        public override string GetLocalFileName(HttpContentHeaders headers)
        {
            string filePath = headers.ContentDisposition.FileName;

            // Multipart requests with the file name seem to always include quotes.
            if (filePath.StartsWith(@"""") && filePath.EndsWith(@""""))
                filePath = filePath.Substring(1, filePath.Length - 2);
           return Path.GetFileNameWithoutExtension(filePath)+ DateTime.Now.ToString("_yyyyMMddHHmmss_ffff", DateTimeFormatInfo.InvariantInfo) + Path.GetExtension(filePath).ToLower();
            return filePath;
        }

    }

第四步:kindeditor配置:

主要配置的是UploadJson参数:saveDir代表保存的目录,dfs代表是否上传到图片服务器,如果dfs=1代表上传到图片服务器否则上传到本地。

时间: 2024-10-03 21:59:47

kindeditor扩展粘贴图片功能&修改图片上传路径并通过webapi上传图片到图片服务器的相关文章

修改帝国CMS默认图片附件上传路径

帝国CMS系统设置中的"附件地址"设置是不生效的,无论设置成什么都还是在 d/file/ 下,下面牛教程介绍手动修改附件存放地址的方法. 一:先在系统设置中将"附件地址"一项修改为自己想要的地址,这里以 /upload/ 为例. 二:修改 /e/class/connect.php 文件,将文件中所有 d/file/ 替换为 upload/ 值,修改位置在2964行左右. 三:手动创建 upload 文件夹. 修改这三项后就算成功修改附件上传路径了. 需要注意的是,如

UMEditor(Ueditor mini)修改图片上传路径

UMEditor(Ueditor mini)修改图片上传路径 imageUp.ashx string pathbase = "/UpLoad/images/"; //保存文件夹在网站根目录下 dialogs/image/image.js //修改为 var $img = $("<img src='" + url + "' class='edui-image-pic' />"),//去掉editor.options.imagePath,

在线修改图片尺寸缩放网站(完美解决图片过大无法上传问题)

在线修改图片尺寸缩放网站(完美解决图片过大无法上传问题) http://pic.sdodo.com/tool/picadjust/ http://www.zhengzong.cn/bbsxp/thread-8136-1-1.html 一次使用windows xp用头像是用到 因头像尺寸标准为48*48 Look! 成功修改的小猫咪! Windows Xp / 2003用户头像位置 C:\Documents and Settings\All Users\Application Data\Micro

ueditor1.4.3 php版本使用修改图片上传路径

实例化编辑器必须带上一下东西 header部分 <script type="text/javascript" charset="utf-8" src="ueditor.config.js"></script> <script type="text/javascript" charset="utf-8" src="ueditor.all.min.js">

thinkphp开发系列-ueditor1.43修改图片上传路径

最近用的ueditor1.43感觉分厂不错,但是如何能自定义ueditor的上传路径呢 然后进入php目录 打开后参考下图修改

umeditor1.2.2 jsp版本更改图片上传路径的方法

最近在做一个bbs项目,需要一个轻量级的编辑器,看过来看过去,都是百度编辑器挺好看的 怎么部署百度编辑器我就只截取部分图片,关键是更改图片上传路径的方法 这是部署百度编辑器需要的引入的js文件,目录要对应 在网页需要编辑器的地方添加这段代码,写好样式表,直接要class引入,编辑器的长宽就会自适应,后面的内容会在百度编辑器初始化后自动填写在百度编辑器中, 你可以试一下,name属性是后台接受表单提交是获取内容时使用的字段 UM.getEditor("myEditor");这句是初始化百

html + js 实现图片上传,压缩,预览及图片压缩后得到Blob对象继续上传问题

先上效果 上传图片后(设置了最多上传3张图片,三张后上传按钮消失) 点击图片放大,可以使用删除和旋转按钮 (旋转功能主要是因为ios手机拍照后上传会有写图片被自动旋转,通过旋转功能可以调正) html页面 需要引入weui.min.css 不然没法渲染样式, 将下面的代码放在需要上传文件的地方就行了,如果不需要图片旋转功能, 可以直接删掉那个div, 改不改js无影响 addPhoto.html <!--图片缩略图--> <div class="weui-cells weui-

ASP.NET图片上传,加水印文字和水印图片!

看了清清月儿的这篇文章让自己受益匪浅,但是觉得还有一些问题.上传图片后还有原来的图片文件存在,觉得这样很不爽,调用file类的delete方法删除原来没有生成水印的图片另外自己又加了一个限制图片大小的函数 1.最简单的单文件上传(没花头) 效果图:说明:这是最基本的文件上传,在asp.net1.x中没有这个FileUpload控件,只有html的上传控件,那时候要把html控件转化为服务器控件,很不好用.其实所有文件上传的美丽效果都是从这个FileUpload控件衍生,第一个例子虽然简单却是根本

v9切换ueditor后图片上传路径问题 改成绝对路径

使用V9切换成ueditor编辑器后,图片上传路径显示的是相对路径,同时会把content字段第一张图这个路径同步到缩略图的thumb字段.thumb字段如果是相对路径的话,前端就不能进行裁剪,APP或者其他应用也不能调用. 于是修改. 我用的是1.4.3版本 找到编辑器目录下的/php/Uploader.class.php文件. 找到getFileInfo()方法,修改成如下代码     public function getFileInfo()     { $dangqian_host =