2019独角兽企业重金招聘Python工程师标准>>>

 前段时间发表过一篇关于“KindEditor在JSP中使用”的博文。这几天在沈阳东软进行JavaWeb方面的实习工作,在一个CMS系统的后台和博客板块中又要用到文本编辑器,突然发现了这个——百度编辑器(官网http://ueditor.baidu.com/website/index.html)。

  Ueditor由百度开发,传说中的百度更懂中文嘛,不像KindEditor有时会显示乱码。Ueditor提供中文“utf-8”和“gbk”版本的下载。而且分为完整版和定制版。完整版没什么可说的,下面说下定制版:

  定制版就是可以选择自己需要的功能,然后根据用户所选组件生成下载包。地址(http://ueditor.baidu.com/website/ipanel/panel.html)。定制的内容包括组件,编辑器背景颜色或图片,编辑器高度和宽度等;

  值得一提的是,Ueditor提供了功能说明文档和使用说明文档。可以让开发者快速的清楚他能实现的功能,并节约阅读原JS代码的时间,熟练的使用Ueditor。文档链接(http://ueditor.baidu.com/website/document.html),附使用说明文档(摘自Ueditor官网):

前后端数据交互

2012-05-11 16:09:13

一、富文本内容交互

1编辑器内容初始化(即往编辑器中设置富文本)

场景一:写新文章,编辑器中预置提示、问候等内容。

在editor_config.js文件中找到initialContent参数,设置其值为需要的提示或者问候语即可,如initialContent:’欢迎使用UEditor!’。

场景二:编辑旧文章,从数据库中取出富文本放置到编辑器中。

显然,编辑文章时需要从后台数据库中取出大段富文本,如果仍然采用场景一中的方式去设置初始值的话,必然会带来诸如引号匹配被截断等问题,因此需要采用另外一种方式去设置,如下代码所示:

1

2

3

<script type="text/plain" id="editor">

    //从数据库中取出文章内容打印到此处

</script>

此处采用了script标签作为编辑器容器对象,并设置了其类型是纯文本,从而在避免了标签内部JS代码执行的同时解决了部分同学在使用传统的textarea标签作为容器所带来的一次额外转码问题。

2提交编辑器内容至后端

场景一:在编辑器所在的Form中存在提交按钮,提交动作由点击此按钮完成。

该场景适用于最普通的场合,没有太大问题需要注意,仅三点说明:

1) 默认情况下提交到后台的表单名称是 “editorValue”,在editor_config.js中可以配置,参数名为textarea。

2) 可以在容器标签(即script标签)上设置name属性,以覆盖editor_config.js中的默认配置。实例代码如下,此处的myContent将成为新的提交表单名称:

1

2

3

4

5

<form action="" method="post">

    <script type="text/plain" id="editor" name="myContent">

    </script>

    <input type="submit" name="submit" value="提交">

</form>

3)后端接收程序可以通过如下几种方式来获取编辑器中的富文本内容。

1

2

3

4

5

6

7

8

9

10

11

//PHP获取:

$_POST["myContent"]

    

//JSP获取:

request.getParameter("myContent");

    

//ASP获取:

request("myContent");

    

//NET获取:

context.Request.Form["myContent"];

场景二:编辑器所在的Form中不存在提交按钮,提交动作由外部事件触发。

该场景适用于站点前端交互较多的场合,需要注意的事项主要是在触发form提交动作之前执行编辑器内容同步操作。一般的代码模式如下所示:

1

2

3

4

5

//满足提交条件时同步内容并提交,此处editor为编辑器实例

if(editor.hasContent()){ //此处以非空为例

    editor.sync();       //同步内容

    someForm.submit();   //提交Form

}

此处editor是编辑器实例对象。

场景三:编辑器不在任何Form中,提交动作由外部事件触发。

该场景使用不多,但特殊时候可能需要。UEditor也提供了对应的处理方案,基本逻辑跟场景二一样,只是在执行同步操作的时候需要传入提交form的id,如editor.sync(myFormID)即可。其他同场景二。

二、图片上传交互

1传统图片上传

传统图片上传涉及到的前后端交互主要涉及“上传提交路径”以及“图片保存路径”两个参数,后台保存路径以任何形式(绝对或者相对)、在任何页面展示跟前台无关。

2Flash图片上传

Flahs图片上传和传统图片上传存在一个很大的区别:它需要服务器端实时返回“图片保存路径”用于在前台的即时展示。具体到编辑器,就是需要将返回的路径插入到编辑器中。由此会引出除传统图片上传中提到的两个参数之外的第三个参数:“前后端修正路径”。如果后台返回的保存路径是绝对路径(指以http开头的路径,以根目录开始的路径也可勉强归入其中),那么前台无须做任何修正,否则用户必须十分清楚自己当前的目录结构并据此修正这个前后端相对路径之间的差异。因此,UEditor极力推荐由服务器端返回以根目录开始的相对路径。

3UEditor中的上传实践及注意事项

在UEditor中,“上传提交路径”和“前后端修正路径”的配置位于editor_config.js中。其中,imageUrl参数对应着“上传提交路径”,imagePath参数对应着“前后端修正路径”。而“图片保存路径”则需要在server/upload/php目录下的imageUp文件中配置。

路径配置完成之后,还需要配置imageFieldName参数作为文件表单的表单名,后台可以据此获取文件句柄。该参数同样位于editor_config.js中。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

//图片上传提交地址

imageUrl:URL+"server/upload/php/imageUp.php",

        

//图片修正地址,引用了fixedImagePath,如有特殊需求,可自行配置 

imagePath:fixedImagePath,

        

//图片描述的key             

imageFieldName:"upFile",

        

//等比压缩的基准,确定maxImageSideLength参数的参照对象.

//0为按照最长边,1为按照宽度,2为按照高度                      

compressSide:0,   

        

//上传图片最大允许的边长,超过会自动等比缩放,不缩放就设置一个比较大的值

//更多设置在image.html中                          

maxImageSideLength:900

完成上述配置之后,理论上后台应该可以接收到前台上传的图片文件了。在正确保存之后,传统图片上传至此就结束了。但是,在使用Flash上传的编辑器中,流程还远未结束。

首先,后台需要计算得出图片文件存放的地址字符串。该字符串UEditor极力推荐使用从网站根目录开始算起,一直到图片名结束为止。如果不从网站根目录开始算起,后面需要考虑“前后端修正地址”参数。

其次,后台返回一个json格式的字符串,格式具体要求如下:

1

"url":"图片地址""title":"图片描述""state":"上传状态" }

其中,url对应计算出的图片保存地址——再强调一遍,尽量构造出从网站根目录开始的地址字符串;title对应flash中的描述字段,在图片上将会被设置到title属性中;state对应服务器端返回的图片上传状态字符:除了上传成功返回“SUCCESS”之外,其他任何值都将被直接显示在返回的图片描述字段内。

最后,UEditor会在返回的url地址前面增加“前后端修整路径”这个参数值作为最后插入编辑器中的图片地址。因此,如果服务器端返回的是从根目录开始的图片路径或者http开头的绝对路径,“前后端修正路径”必须留空。

举例来讲,如果服务器返回的路径是“/myProject/uploads/sun.jpg”,那么插入到编辑器中的路径会是“前后端修正路径 +  /myProject/uploads/sun.jpg”。

三、Word图片转存交互

1图片转存原理

所谓word图片转存,是指UEditor为了解决用户从word中复制了一篇图文混排的文章粘贴到编辑器之后,word文章中的图片数据无法显示在编辑器中,也无法提交到服务器上的问题而开发的一个操作简便的图片转存方案。

该功能的基本操作步骤:复制word文档——》粘贴到编辑器——》编辑器会将所有图片转换成一个占位图,同时在工具栏中高亮转存按钮——》点击转存按钮弹出图片上传框——》点击复制按钮复制图片目录地址——》点击“添加照片”按钮,在弹出的选择框中粘贴刚复制的图片目录地址——》点击打开按钮,选择目录下的所有图片文件,在此点击打开——》执行图片上传——》上传成功确认插入,UEditor将自动完成对应占位图的替换过程。

2配置要点及注意事项

word图片转存跟普通图片上传的配置基本一样,所不同的仅仅是操作上的差异:前者需要首先获取临时图片文件存在的目录,后者直接选择自己指定的文件目录。PS:在部分操作系统的部分版本word中发现单张word图片会生成两张临时图片,且格式不一,清晰度各异,目前暂时未发现改进方法。

四、远程图片抓取交互

1远程抓取原理

图片远程抓取是指在插入本地域名之外的图片链接地址时,由服务器将这些外部图片抓取到本地服务器保存的一个功能。实现原理为在编辑器中向服务器发送包含所有外域图片地址的ajax请求,然后由服务器在后端抓取保存后返回图片地址给编辑器,再由编辑器完成外域地址和本地地址的替换工作。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

//是否开启远程图片抓取

catchRemoteImageEnable:true,

                                        

//处理远程图片抓取的地址

catcherUrl:URL +"server/submit/php/getRemoteImage.php"

              

//提交到后台远程图片uri合集的表单名

catchFieldName:"upFile",    

                                          

//图片修正地址,同imagePath

catcherPath:fixedImagePath,

        

//本地顶级域名,当开启远程图片抓取时,除此之外的所有其它域名下的

//图片都将被抓取到本地                                  

localDomain:["baidu.com","10.81.2.114"],

2注意事项

远程抓取功能是否开启可在edicot_config.js中通过配置catchRemoteImageEnable参数实现。与这个功能相关的配置还包括了远程抓取的处理程序地址,表单域名称,本地域和“前后端修正地址”。远程抓取处理程序实现了依据前端提交的地址列表(使用ue_separate_ue标示符进行分隔的字符串)进行图片抓取,然后返回地址列表给客户端的功能。

前后台交互数据格式样例:(URL1,URL2,URL3,URL4)

1

URL1ue_separate_ueURL2ue_separate_ueURL3ue_separate_ueURL4

五、图片在线管理交互

1图片在线管理介绍

图片在线管理是指通过读取服务器端的文件目录并将其展示到编辑器中的进行额外一些操作的功能。处于安全考虑,目前UEditor仅实现了图片二次插入操作,其他诸如删除、移动等操作将会在后续二次开发教程中陆续放出。

1

2

3

4

5

//图片在线管理的处理地址       

imageManagerUrl:URL + "server/submit/php/imageManager.php",

              

//图片修正地址,同imagePath       

imageManagerPath:fixedImagePath

2注意事项

图片在线管理需要配置的参数跟远程图片抓取一致,两者不同的地方是图片在线管理中的图片数据是由服务器端指定某个目录,然后遍历其下的所有图片文件得到,然后将地址返回给编辑器,而远程图片抓取则是由编辑器提交图片地址,经过服务器端的抓取处理后返回新的地址给编辑器。两者的初始触发都需要ajax的介入。

六、屏幕截图交互

1屏幕截图介绍

使用了ActiveX控件,目前只支持IE浏览器。

2注意事项

需要配置的参数除了跟图片上传一样的内容之外,还多出了服务器地址和端口的配置。具体使用时请根据自身服务器的特点做出适应修改。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

//屏幕截图的server端文件所在的网站地址或者ip,请不要加http://

snapscreenHost: '127.0.0.1',    

       

//屏幕截图的server端保存程序,UEditor的范例代码为“URL                             

snapscreenServerUrl: URL +"server/upload/php/snapImgUp.php", +"server/upload/php/snapImgUp.php"

       

//屏幕截图的server端端口

snapscreenServerPort: 80

       

//截图的图片默认的排版方式                                

snapscreenImgAlign: 'center'

       

//截图显示修正地址                             

snapscreenPath: fixedImagePath,

七、附件上传交互

1附件上传注意事项

附件上传的基本配置跟图片类似。另外,由于附件上传采用了相当成熟的swfupload开源框架,因此大部分的文档和资料尽可参考swfupload的官网教程。官网地址:http://www.swfupload.org

  

  Ueditor的部署说明(摘自Ueditor官网):

完整版的部署与体验

2012-05-11 16:16:57

一、官网上下载完整源码包,解压到任意目录,解压后的源码目录结构如下所示:

_examples:编辑器完整版的示例页面

_demos:编辑器的各种使用案例

dialogs:弹出对话框对应的资源和JS文件

themes:样式图片和样式文件

server:涉及到服务器端操作的PHP、JSP等文件

third-party:第三方插件

editor_all.js:_src目录下所有文件的打包文件

editor_all_min.js:editor_all.js文件的压缩版,建议在正式部署时才采用

editor_config.js:编辑器的配置文件,建议和编辑器实例化页面置于同一目录

二、部署UEditor到实际项目(UETest)中的步骤:

图表 1

第一步:在项目的任一文件夹中建立一个用于存放UEditor相关资源和文件的目录,此处在项目根目录下建立,起名为ueditor。

第二步:拷贝源码包中的dialogs、themes、third-party、editor_all.js和editor_config.js到ueditor文夹中。其中,除了ueditor目录之外的其余文件均为具体项目文件,此处所列仅供示例。

第三步:为简单起见,此处将以根目录下的index.php页面作为编辑器的实例化页面,用来展示UEditor的完整版效果。在index.php文件中,首先导入编辑器需要的三个入口文件,示例代码如下:

1

2

3

4

5

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>编辑器完整版实例</title>

<script type="text/javascript" src="ueditor/editor_config.js"></script>

<script type="text/javascript" src="ueditor/editor_all.js"></script>

<link rel="stylesheet" href="ueditor/themes/default/ueditor.css">

第四步:然后在index.php文件中创建编辑器实例及其DOM容器。具体代码示例如下:

1

2

3

4

5

<div id="myEditor"></div>

<script type="text/javascript">

    var editor = new baidu.editor.ui.Editor();

    editor.render("myEditor");

</script>

最后一步: 在/UETest/ueditor/ editor_config.js中查找URL变量配置编辑器在你项目中的路径。

1

2

//强烈推荐以这种方式进行绝对路径配置

URL= window.UEDITOR_HOME_URL||"/UETest/ueditor/";

至此,一个完整的编辑器实例就已经部署到咱们的项目中了!在浏览器中输入http://localhost/UETest 运行下试试UE强大的功能吧!

三、注意事项

1.在引用editor_config.js时,最好先于editor_all.js加载,否则特定情况下可能会出现报错。

2.若希望给编辑器赋初值,请将上面描述index.php的div换成初始内容

3. 需要注意的是编辑器资源文件根路径。它所表示的含义是:以编辑器实例化页面为当前路径,指向编辑器资源文件(即dialog等文件夹)的路径。鉴于很多同学在使用编辑器的时候出现的种种路径问题,此处强烈建议大家使用"相对于网站根目录的相对路径"进行配置。"相对于网站根目录的相对路径"也就是以斜杠开头的形如"/UETest/ueditor/"这样的路径。

此外如果你使用的是相对路径,例如"ueditor/"(相对于图表1路径结构)

如果站点中有多个不在同一层级的页面需要实例化编辑器,且引用了同一UEditor的时候,可能不适用于每个页面的编辑器。因此,UEditor提供了针对不同页面的编辑器可单独配置的根路径,具体来说,在需要实例化编辑器的页面最顶部写上如下代码即可。

当然,需要令此处的URL等于对应的配置。window.UEDITOR_HOME_URL ="/xxxx/xxxx/";

  OK,Ueditor在官网上的叙述已经很为详细,本博就简单的作下说明。

评论

#1楼 2013-03-27 17:09忧虑似水

1

echo '你好,再见';

支持(1)反对(0)

#2楼 2013-03-31 00:54九筒

1

dddd

支持(0)反对(0)

#3楼 2013-10-09 17:35传说的烧饼

1

echo "Hello World!";

支持(0)反对(0)

#4楼 2013-12-27 12:00Quietly elegant

路径问题是个大问题,配置也相当繁琐,反正不推荐新手

支持(1)反对(0)

#5楼 2014-01-16 17:29爱钻牛角尖的程序猿

相当不错的一个编辑器,年初的时候为了弄到自己项目里费了不少劲,最近又一次需要了,反而能通过几个简单的属性设置达到自己的目的。

支持(0)反对(0)

#6楼 2014-03-20 19:18花间词

echo 'lala';

支持(0)反对(0)

#7楼 2014-03-25 16:39女子100

怎么删多余功能?好多功能啊,烦,,,

支持(0)反对(0)

#8楼 2014-04-10 10:37丶奈落

用的我快吐血了 还好?

支持(1)反对(0)

#9楼 2015-08-08 22:52青岛星网

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>编辑器完整版实例</title>
<script type="text/javascript" src="ueditor/editor_config.js"></script>
<script type="text/javascript" src="ueditor/editor_all.js"></script>
<link rel="stylesheet" href="ueditor/themes/default/ueditor.css">

支持(1)反对(0)

#10楼 2015-09-30 15:51梁梁的甜甜的

差不多弄了我一天,快崩溃了都。

支持(0)反对(0)

#11楼 2015-11-05 18:19我的云儿时代哦

echo "Hello World!!!";

支持(0)反对(0)

#12楼 2016-04-25 10:59冰缘丶

还可以吧

转载于:https://my.oschina.net/zyt1978/blog/683155

百度编辑器-Ueditor相关推荐

  1. 百度html在线编辑器插件,百度编辑器UEditor插件DjangoUeditor v1.8.143

    DjangoUeditor将Ueditor封装为一个Django app,提供文件/图片等上传功能,提供UEditorField.UEditorWidget等封装类,简化Ueditor在Django中 ...

  2. php百度编辑器精简版,开源web编辑器|百度编辑器ueditor下载1.4.3.4php版 下载_久友软件下载...

    百度编辑器ueditor是由百度官方推出的开源web编辑器.百度编辑器ueditor能支持用户在网页上进行内容编辑,软件体积十分的轻巧,完全免费开源,加载速度极快,兼容所有主流的浏览器使用,如:Moz ...

  3. 【百度编辑器ueditor】工具,如何去掉百度编辑器 ueditor 元素路径、字数统计等...

    去掉如下截图: 在百度编辑器 ueditor 根目录下: ueditor.config.js 文件中 搜索并将参数elementPathEnabled设置成false即可 常用功能开关如下: ,ele ...

  4. 百度编辑器ueditor 字符限制

    百度编辑器ueditor 字符限制 默认只能输入10000个字符 修改 ueditor.config.js // ,wordCount:true //是否开启字数统计// ,maximumWords: ...

  5. 解决:百度编辑器UEditor,怎么将图片保存到图片服务器,或者上传到ftp服务器的问题(如果你正在用UE,这篇文章值得你看下)

    解决:百度编辑器UEditor,怎么将图片保存到图片服务器,或者上传到ftp服务器的问题(如果你正在用UE,这篇文章值得你看下) 参考文章: (1)解决:百度编辑器UEditor,怎么将图片保存到图片 ...

  6. 下载百度编辑器ueditor

    微信后台开发中, 一个重要的功能是让用户编辑文章发布, 由于我们下载的bootstrap后台模板, 默认的编辑器功能有限, 所以在这里, 我们使用国内一款开源的编辑器--百度编辑器 功能强大, 只要你 ...

  7. 基于百度编辑器Ueditor的二次开发

    基于百度编辑器Ueditor的二次开发 官网下载 基本配置 简化后端配置,不请求后端配置项 后端接口规范 修改图片上传 说明及修改 新增按钮及弹窗(自定义附件上传) 按钮文案修改 在业务开发的时候,曾 ...

  8. 帝国cms html5 编辑器,帝国CMS修改默认编辑器为百度编辑器UEditor的方法

    帝国默认编辑器确实非常难用,今天开拓族做了一个教程用最简单的方法来替换默认编辑器的方法! 同时支持前台投稿和后台发布! 效果演示 下载百度编辑器ueditor,将ueditor解压到后上传到帝国的插件 ...

  9. 百度编辑器ueditor上传视频后,再次编辑视频无法播放

    开发过程使用百度编辑器ueditor,第一次上传视频可正常播放.第二次编辑一个视频无法播放! 只需修改ueditor.config.js中两行配置即可: 把img修改成:img:    ['src', ...

  10. 百度编辑器ueditor使用

    百度编辑器ueditor使用  引入步骤: ueditor放到相应目录 比如\blog\Public\admin 2.页面head中加入js <script type="text/ja ...

最新文章

  1. c语言 静态链表插入排序,数据结构C语言版 表插入排序
  2. 针对《评人工智能如何走向新阶段》一文,继续发布国内外的跟贴留言449-456条如下:
  3. [转]C++函数模板与模板函数
  4. 基于springboot+vue实现外卖点餐系统
  5. 五子棋java判断平局_2020-10-03 Java初级项目——从零开始制作一个简易五子棋游戏...
  6. [html] 说说你对Media Source Extensions(MSE)的理解,它解决了什么问题呢?
  7. springMVC集成缓存框架Ehcache
  8. 【干货】微信私域运营实战指南.pdf(附下载链接)
  9. win7主机与linux虚拟机共享方法之右键添加Sharing Options
  10. yii2 获取模块名,控制名,动作方法名
  11. 重启mysql tomcat_linux下MySQL、Tomcat、Redis、Nginx停止和重启
  12. 锐捷DHCPV6配置
  13. html页面加载蒙版,HTML / CSS - 在图像上创建alpha蒙版
  14. NetLimiter网速测试小坑
  15. HDU-6468 zyb的面试(模拟十叉树+dfs)
  16. GitHub标星90K,这份持续霸榜的Leetcode刷题手册到底有多强?
  17. 打怪游戏 勇者打恶龙1.6(1.7)
  18. excel将一个工作表根据条件拆分成多个工作表,并将多个工作表怎么拆分成独立表格
  19. 2015阿里系统工程师面试经验分享(广州站)
  20. vscode代码自动格式化快捷键

热门文章

  1. 仿豆瓣首页【web前端项目】
  2. checkstyle.xml自定义规则文件的编写
  3. Python爬虫实现12306火车票查询
  4. Java- 数据结构之树
  5. linux面试宝典 pdf,运维工程师面试题(面试版).pdf
  6. CountDownLatch导致的线程阻塞问题及线程池的使用
  7. js中session的使用
  8. 南京软博会圆满落幕,数睿数据企业级无代码受关注
  9. 2017.02.04,读书,2017第二本《把时间当作朋友》读书笔记
  10. Logrotate日志切割