百度UEditor在线编辑器的配置和图片上传

摘要:
前言:该项目最近使用了百度UEditor富文本编辑器。在配置UEditor的过程中遇到了几个问题。请在此处记录解决方案和用法,以避免将来使用UEditor时出现类似错误。基本配置1。下载UEditor.NET版本开发包。图1图24。在Views=˃Shared=˃_UEditor的必要JS文件被引入Layout.cshtml文件中。在Index视图中添加textarea标记和相关的JS代码以显示编辑器。有关更多配置,请参阅ueditor.config.js中的配置说明。为了在编辑器中显示图像,我们还需要配置图像访问路径前缀以及上传和保存路径。

前言

      最近在项目中使用了百度UEditor富文本编辑器,配置UEditor过程中遇到了几个问题,在此记录一下解决方案和使用方法,避免以后使用UEditor出现类似的错误。

基本配置

一、下载UEditor.NET版本开发包。

UEditor可以到 http://ueditor.baidu.com/website/download.html#ueditor 进行下载,我们这里选用1.4.3.3 .NET版本。

QQ截图20160815113251

二、把UEditor开发包放到项目里面。

1、新建一个ASP.NET MVC 4应用程序

image

2、选择基本项目模板。

image

3、把开发包的必要的文件放到项目里面。

首先我们在项目Script目录下新建一个ueditor文件夹用来保存图1所示的JS文件,然后在项目根目录创建一个Common文件夹用来保存图2所示的后台处理文件。

图1image 图2image

4、在Views=>Shared=>_Layout.cshtml文件里面引入UEditor必要的JS文件。

复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width" />
    <title>@ViewBag.Title</title>
    @Styles.Render("~/Content/css")
    @Scripts.Render("~/bundles/modernizr")
</head>
<body>
    @RenderBody()

    @Scripts.Render("~/bundles/jquery")
    <script src="http://t.zoukankan.com/~/Scripts/ueditor/ueditor.config.js"></script>
    <script src="http://t.zoukankan.com/~/Scripts/ueditor/ueditor.all.js"></script>
    @RenderSection("scripts", required: false)
</body>
</html>
复制代码

注意:ueditor.config.js和ueditor.all.js前后顺序不能写反了

5、创建UEditorController并添加视图。

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;

namespace UEditorDemo.Controllers
{
    public class UEditorController : Controller
    {
        [ValidateInput(false)]
        public ActionResult Index(FormCollection fc)
        {
            var content = fc["container"];
            return View();
        }
    }
}
复制代码

注意:在Index Action上面要加上[ValidateInput(false)]特性

image

注意:在添加Index视图的时候需要引入_Layout.cshtml母版页。

在Index视图里面添加textarea标签和相关JS代码用来显示编辑器,更多配置可参考ueditor.config.js里面的配置说明。

复制代码
@{
    ViewBag.Title = "Index";
    Layout = "~/Views/Shared/_Layout.cshtml";
}

@using (Html.BeginForm("Index", "UEditor"))
{
    <textarea   name="container"></textarea>
    <br />
    <input type="submit" value="提交" />
}

@section scripts{
    <script>
        $(function () {
            var editor = UE.getEditor('container', {
                minFrameHeight: 500,
                initialFrameHeight: 500,
                autoHeightEnabled: true,
            });
        });
    </script>
}
复制代码

到目前为止,正常情况下,页面上已经能显示出来编辑器的样子了。现在我们输入“测试”内容,点击提交按钮,后台也能获取到刚才输入的“测试”内容,如图所示:

image

image

配置图片上传

在基本配置中,我们可以把文本内容上传到服务器,这时候我们想上传一张图片到服务器,发现上传图片的按钮是禁用状态,并且在打开多图上传对话框=>本地上传选项卡显示:后端配置项没有正常加载。这是为什么呢?通过查找文档发现是因为没有配置ueditor.config.js文件的serverUrl属性,现在让我们动手配置一下试试吧。

image

1、配置serverUrl属性。

由于我们的controller.ashx放在Common文件夹下面,所以我们打开ueditor.config.js文件把属性serverUrl改为:

serverUrl: "/Common/controller.ashx"

2、配置图片访问路径前缀和上传保存路径。

为了能够让图片在编辑器里面显示,我们还需要配置图片访问路径前缀和上传保存路径。

1)打开Common文件夹下面的config.json文件,我们把imageUrlPrefix属性改为:

"imageUrlPrefix": "http://192.168.199.171/UploadFiles/", /* 图片访问路径前缀 */

注意:需要在iis默认站点里面添加一个别名为“UploadFiles”的应用程序,并指定相应的物理路径,上传的图片才能在编辑器里面显示。

2)把imagePathFormat属性修改为:

"imagePathFormat": "/upload/image/{yyyy}{mm}{dd}/{time}{rand:6}", /* 上传保存路径,可以自定义保存路径和文件名格式 */

注意:在upload路径前面加了一个“/”。

现在应该可以上传图片并在编辑器里面进行显示了,如下图所示:

image

image

图片上传进阶

在实际的项目中,我们上传图片可能保存在别的盘符下面以及访问图片的域名也需要改变,一般是后台可配的,这时候我们可以通过修改后台代码实现这种需求。

1、修改UploadHandler.cs文件。

打开Common=>UploadHandler.cs文件找到下面的代码,修改LocalPath和Result.Url变量即可得到想要的效果。

复制代码
var savePath = PathFormatter.Format(uploadFileName, UploadConfig.PathFormat);  //修改地方1
var localPath = Server.MapPath(savePath);
try
{
    if (!Directory.Exists(Path.GetDirectoryName(localPath)))
    {
        Directory.CreateDirectory(Path.GetDirectoryName(localPath));
    }
    File.WriteAllBytes(localPath, uploadFileBytes);
    Result.Url = string.Format("http://192.168.199.171/sowerestres/Notice/{0}", savePath);  //修改地方2
    Result.State = UploadState.Success;
}
catch (Exception e)
{
    Result.State = UploadState.FileAccessError;
    Result.ErrorMessage = e.Message;
}
finally
{
    WriteResult();
}
复制代码

2、修改ListFileHandler.cs文件。

打开Common=>ListFileHandler.cs文件找到下面的代码,修改LocalPath和PathToList变量即可得到想要的效果。

public ListFileManager(HttpContext context, string pathToList, string[] searchExtensions)
        : base(context)
    {
        this.SearchExtensions = searchExtensions.Select(x => x.ToLower()).ToArray();
        this.PathToList = "http://192.168.199.171/sowerestres/Notice/";  //修改地方1
    }
复制代码
try
{
    var localPath = Server.MapPath(PathToList);  //修改地方2
    buildingList.AddRange(Directory.GetFiles(localPath, "*", SearchOption.AllDirectories)
        .Where(x => SearchExtensions.Contains(Path.GetExtension(x).ToLower()))
        .Select(x => PathToList + x.Substring(localPath.Length).Replace("\", "/")));
    Total = buildingList.Count;
    FileList = buildingList.OrderBy(x => x).Skip(Start).Take(Size).ToArray();
}
catch (UnauthorizedAccessException)
{
    State = ResultState.AuthorizError;
}
catch (DirectoryNotFoundException)
{
    State = ResultState.PathNotFound;
}
catch (IOException)
{
    State = ResultState.IOError;
}
finally
{
    WriteResult();
}
复制代码

以上是本人在.net mvc项目中使用ueditor编辑器的简单配置,欢迎转载和使用。

同时附上Demo下载地址:http://pan.baidu.com/s/1nvc0hAx (提取码:61l0)

免责声明:文章转载自《百度UEditor在线编辑器的配置和图片上传》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Mybatis 笔记python 文件操作下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

UEditor百度网页编辑器JSP版配置与调试

  最近用公司后台时发现那编辑器还难用,就想着给它换一个。在网上找了下资料也对比了一下,后决定用百度的UEditor。 在UEditor官网下载了一个开发版1.4.3.3Jsp 版本UTF-8编码的压缩包。在MyEclipse新建了一个项目,把解压出来的文件丢在项目中运行了一下。 我以为就这么完美的运行了呢!然后逐个功能试了一下发现要上传的功能都没用提示...

php批量上传图片并把图片名放入数据库

第一步肯定是首先把图片上传到对应的图片目录下,直接用框架中已经有的上传类: try{ $upload=newUpload(); $upload->set_ext(array('zip')); $path='目录名'; if( ! Io::mkdir($path)) // 创建目录 { thrownewException("无...

php 保存编辑器内容中的远程图片为本地图片

有时,我们的编辑器复制过来的图片是远程的,需要下载到本地服务器上。 1、提取远程图片 /* *功能:php完美实现下载远程图片保存到本地 *参数:文件url,保存文件目录,保存文件名称,使用的下载方式 *当保存文件名称为空时则使用远程文件原来的名称 */ private function getImage($url,$filename='...

ABAP 上传图片

Sap图片上传程序: 1、  全局字段定义 types: begin of ty_pic,           pic_data(1024) type x,         end of ty_pic.data: pic_tab type table of ty_pic.data: wa_pic type ztpic.data: c_pic type re...

修改git commit默认触发的编辑器

使用git commit会自动启动编辑器编辑本次提交的comment,git默认配置是GNU nano,但是很多人不是很熟悉(我就是),其实这个是可以自行配置的。 编辑制定代码库的.git/config文件,一般长这样: [core] repositoryformatversion = 0 filemode = true bare = false...

【微信】新闻推送步骤

微信公众平台主页 准备群发素材 这里演示多图文消息情况—— 群发消息 在素材中找之前编辑好的内容 补充:微社区后台设置 进入微社区后点击【话题管理】-【发新话题】,然后进行复制粘贴即可(注意:图片需要下载后上传到微社区里,无法粘贴) 记得把标签改为【七院动态】 编辑好后提取网页链接 补充:编辑器用法略讲 所有编辑器基本都差不多,...