百度文本编辑器 Ueditor for net 使用七牛存储附件的实现_.NET_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > .NET > 百度文本编辑器 Ueditor for net 使用七牛存储附件的实现

百度文本编辑器 Ueditor for net 使用七牛存储附件的实现

 2014/7/21 21:39:05  ‰流浪※  程序员俱乐部  我要评论(0)
  • 摘要:百度编辑器功能强大,确实好用,可惜附件使用本地存储,如果网站的用户量巨大,则会使得网站目录变得非常庞大,而且文件不易于管理,七牛云存储在附件存储方面下了不少功夫,用起来感觉不错,要是将ueditor的附件存储改为七牛,那就解决大量帖子的附件存储问题了下载新版的ueditorfornet,解压后直接将ueditor目录复制到mvc项目目录的根目录下接下来查看/ueditor/net/app_code/uploadHandler.cs,找到下面这段保存附件的代码try{if(!Directory
  • 标签:for 实现 使用 net 百度

百度编辑器功能强大,确实好用,可惜附件使用本地存储,如果网站的用户量巨大,则会使得网站目录变得非常庞大,而且文件不易于管理,七牛云存储在附件存储方面下了不少功夫,用起来感觉不错,要是将ueditor 的附件存储改为七牛,那就解决大量帖子的附件存储问题了

下载新版的 ueditor for net , 解压后直接将ueditor目录复制到mvc 项目目录的根目录下

接下来查看 /ueditor/net/app_code/uploadHandler.cs,找到下面这段保存附件的代码

class="brush:csharp;gutter:true;"> try
        {
            if (!Directory.Exists(Path.GetDirectoryName(localPath)))
            {
                Directory.CreateDirectory(Path.GetDirectoryName(localPath));
            }
            File.WriteAllBytes(localPath, uploadFileBytes);
            Result.Url = savePath;
            Result.State = UploadState.Success;
        }
        catch (Exception e)
        {
            Result.State = UploadState.FileAccessError;
            Result.ErrorMessage = e.Message;
        }
        finally
        {
            WriteResult();
        }

在代码中,可以看到文件被保存在  localPath 中,好吧,开始修改

 try
        {
            if (!Directory.Exists(Path.GetDirectoryName(localPath)))
            {
                Directory.CreateDirectory(Path.GetDirectoryName(localPath));
            }
            //File.WriteAllBytes(localPath, uploadFileBytes);
            //Result.Url = savePath;
           #region < -- 将服务器端文件上传至七牛 -- >
            OssService oss = new OssService();
            Attachment attc = new Attachment();
            FileInfo fi = new FileInfo(uploadFileName);
            attc.FileName = fi.Name;
            attc.FileExt = fi.Extension;
            attc.RelationId = RelationId;
            attc.UserName = OwnerName;
            attc.Uploaddate = DateTime.Now;
            attc.AttachmentType = AttachmentType.goods;
            oss.PutFileToQiniu(localPath, attc);
            #endregion
            Result.Url = attc.FileUrl;
            Result.State = UploadState.Success;
        }
        catch (Exception e)
        {
            Result.State = UploadState.FileAccessError;
            Result.ErrorMessage = e.Message;
        }
        finally
        {
            WriteResult();
        }    

  

OssService 是我项目中一个七牛云存储的文件控制逻辑,具体代码懒得贴出来了,也就是引用七牛的.net 开发包,将文件从服务端保存到七牛云端,用过七牛的都知道怎么回事。Attachment 是我项目中的一个附件对象,处理逻辑已经包含在OssService中了。

 

这里细心的朋友也许就会发现,代码中使用了OwnerName 和 RelationId  两个变量,这两个变量也就是当前网站用户的用户名,还有这个附件相关联的帖子 Id 了,可是在这里怎么得到呢?其实 ueditor 已经给出了扩展的方法,我这里简单提一下,你需要修改uploadHandler 的构造函数,如下

public UploadHandler(HttpContext context, UploadConfig config)
        : base(context)
    {
        this.UploadConfig = config;
        RelationId = context.Request["RelationId"] != null ? context.Request["RelationId"].ToString() : "";
        OwnerName = context.Request["OwnerName"] != null ? context.Request["OwnerName"].ToString() : "";
        this.Result = new UploadResult() { State = UploadState.Unknown };
    }

 

然后呢,修改ueditor 的初始化代码将这两个变量传进来

<script id="container" name="content" type="text/plain">
                    @Html.Raw(Model.DescriptionDetail)
                </script>
                <!-- 配置文件 -->
                <script type="text/javascript" charset="utf-8" src="~/ueditor/ueditor.config.js"></script>
                <!-- 编辑器源码文件 -->
                <script type="text/javascript" charset="utf-8" src="~/ueditor/ueditor.all.js"></script>
                <!-- 实例化编辑器 -->
                <script type="text/javascript">
                    var ue = UE.getEditor('container');
                    ue.ready(function(){
                        ue.execCommand('serverparam', {
                            'RelationId': '@Model.ShopId',
                            'OwnerName': '@User.Identity.Name'
                        });
                    });
                    
                </script>

其实ueditor 已经为我们做好了扩展的接口啦,初始化ueditor 时将这两个变量作为 serverparam 配置好就行了

现在,基本已经可以正常工作了,暂时还是满意的,不过使用中发现如果在ueditor 中使用单个文件上传的功能,发现返回的url 不对,url为 "/ueditor/net/http://xxxx..." ,原来ueditor 自动为我们返回的图片url 添加了前缀,导致编辑时图片不正常,不过要解决这个很简单,直接找到 \ueditor\net\config.json ,将imageUrlPrefix 从 "/ueditor/net/" 修改为 "" 就好了。

 

现在上传文件是搞掂了,下来就是附件列表的问题了。修改 /ueditor/net/app_code/listHandler.cs ,找到这段代码

 1 try
 2         {
 3             var localPath = Server.MapPath(PathToList);
 4             buildingList.AddRange(Directory.GetFiles(localPath, "*", SearchOption.AllDirectories)
 5                 .Where(x => SearchExtensions.Contains(Path.GetExtension(x).ToLower()))
 6                 .Select(x => PathToList + x.Substring(localPath.Length).Replace("\\", "/")));
 7             Total = buildingList.Count;
 8             FileList = buildingList.OrderBy(x => x).Skip(Start).Take(Size).ToArray();
 9             
10         }

 

 1 try
 2         {
 3             //var localPath = Server.MapPath(PathToList);
 4             //buildingList.AddRange(Directory.GetFiles(localPath, "*", SearchOption.AllDirectories)
 5             //    .Where(x => SearchExtensions.Contains(Path.GetExtension(x).ToLower()))
 6             //    .Select(x => PathToList + x.Substring(localPath.Length).Replace("\\", "/")));
 7             //Total = buildingList.Count;
 8             //FileList = buildingList.OrderBy(x => x).Skip(Start).Take(Size).ToArray();
 9             OssService oss = new OssService();
10             Total = oss.GetShopFilesCount(SearchExtensions, RelationId);
11             FileList = oss.GetShopFiles(SearchExtensions, RelationId, Start, Size).ToArray();
12         }

好了,一切ok ,目前用着还可以,唯一不爽的就是 ueditor 的上传附件管理窗口中竟然没有删除附件的功能,恶心,有时间再改吧

上一篇: 一个简单的Webservice的Demo(中)_前端页面调用 下一篇: 没有下一篇了!
  • 相关文章
发表评论
用户名: 匿名