在线编辑器CKeditor,CKfinder
在线编辑器的分类:
常见的在线编辑器有很多,比较常用的有FCKeditor(在线编辑器——Ajax 浏览器
端服务器文件管理器),CKeditor(在线编辑器与服务器端文件管理器的分离,)
其中CKeditor&CKfinder最为常用:
CKeditor:在线编辑器
CKfinder:服务器端文件管理器
CKeditor安装:
下载地址:http://www.ckeditor.com
CKeditor的安装很简单,只需要将文件解压,将CKeditor文件夹放到需要使用的项目位置即可。
CFeditor的目录结构:
使用CKeditor:
CKeditor:简单原理:我们知道,当前能够编辑html源码的表单元素只有textarea,因此在线编辑器的使用都是基于textarea。
怎么使用呢?
1.首先加载CKeditor文件夹中的ckeditor.js
2.界面中必须有一个textarea元素
3.将textarea替换成CKeditor编辑器
3.1最简单的方式:在textarea标签中增加一个class属性,值为CKeditor
3.2标准方式:使用CKeditor提供的类CKEDITOR,以及替换方法replace()。
<script>
CKEDITOR.replace('myck1');//参数为id
</script>
3.3高级方式,使用jquery进行texarea替换
3.3.1 先加载jquery.js
3.3.2 加载ckeditor对jquery提供的接口文件jquery.js。 在/ckeditor/adapters/jquery.js
3.3.3 使用jquery替换textarea元素
<script>
$('#myck1').ckeditor();//参数为id
</script>
注意:以上方式要求textarea元素必须有id或name属性
我们知道了怎么样使用,但有时,原始的样式不是我们期望的,这时就需要对ckeditor进行配置。
如何配置:
ckeditor提供了三种配置方式:
1.修改系统提供的配置文件config.js
例:config.配置项=值
config.width=500;
2.自定义配置文件,形式与系统配置文件config.js一致
2.1新建一个用户配置文件,格式和config.js完全一致
2.2修改配置选项同1
2.3在需要使用客户化的配置文件的ckeditor实例中加载客户定义的配置文件
注意:使用基础班的方式加载ckeditor无法使用客户化的配置文件
<script>
CKEDITOR.replace('myck1',{customConfig:'config_user.js'});//参数为id,config_user.js是我们自定义的配置文件
</script>
优点:只有加载了客户化配置文件的ckeditor实例会受影响,其他的不收影响
3.in-page(页内)配置,在使用ckeditor的界面里进行配置
<script>
CKEDITOR.replace('myck1',{
width:500,
height:200
});//参数为id,
</script>
CKfinder安装同ckeditor
注意:CKfinder下载时需注意选择你所使用的语言的版本
CKfinder目录结构:
使用ckfinder:
要在ckeditor的配置项中加载ckfinder的使用(加载几个静态页,用户文件的管理)
1.在客户化配置文件中进行配置:
2.因为ckfinder默认是不允许用户上传文件的,所以没有权限进行文件上传,需修改配置文件
找到config.php来开放权限
找到CheckAuthentication()方法进行修改
3.修改文件上传路径
在config.php中找到$baseUrl进行修改
4.修改文件上传的目录结构
目录结构不能是单一的就在某个文件类型的文件夹下,应该适当的根据文件上传的量来确定文件夹的结构
如:年/月/日
在config.php中找到$config['ResourceType'][]数组,修改其中的url和directory元素。
5.文件在上传的过程中,如果文件名字是中文或者特殊字符,系统是没有办法进行处理的,上传之后会出现乱码,但是ckfinder没有提供重命名的机制,因此我们需要
修改源码
实现文件重命名:
5.1首先找到源文件路径
新增一个获取随机名字的函数
在哪里调用函数?如何用?
我们知道文件管理器可以在浏览器对服务器进行文件的增删改查,所以我们需要控制用户权限。
控制用户权限:
在config.php中找到$config['AccessControl'][]数组,进行修改
ckeditor编辑内容提交
1.增加form表单,textarea必须要有name属性
2.php接收请求进行处理
我们需要注意的是,因为里面有各种标签,所以在保存时我们需要对内容进行转义操作
$_POST['myck1']=addslashes($_POST['myck1']);之后再存入数据库
这样内容的结构就被改变了,数据再读取之后会影响在浏览器端的显示,
所以必须将内容再转回去进行输出
stripslashes($info);
以上即是ckeditor和ckfinder的基本使用。
在线编辑器CKeditor,CKfinder的更多相关文章
- 在线编辑器Ckeditor (1) - php (30)
在线编辑器 在线编辑器也称之为所见即所得编辑器,是一种常见的html源码编辑器. 所见即所得:用户在输入的时候,不论是格式和是样式都能被系统原封不动的保存,最后在查看的时候,可以按照用户输入的原来的结 ...
- 在线编辑器Ckeditor (2) - php (31)
接上一篇 3 in-page(页内)配置,在使用Ckeditor的界面里进行直接配置 页内配置 效果 特点:配置项完全属于某个特定的Ckeditor实例,不可重用 三种配置方式比较 定制方式 特点 说 ...
- 1.文本编辑器-->CKEditor+CKFinder使用与配置
一.CKEditor介绍 官网地址:http://ckeditor.com CKEditor下载地址:http://ckeditor.com/download CKFinder(免费版本)下载地址:h ...
- CKedit在线编辑器
在线编辑器 在实现所见即得的编辑效果. FCK 是开发者的名字的缩写 CKEditor 功能很完善的,具有,在线编辑与图片上传JS插件 UEdit ...
- .Net在线编辑器:KindEditor及CkEditor+CkFinder配置说明
Net在线编辑器:KindEditor及CkEditor+CkFinder配置说明 一.KindEditor(免费) KindEditor是一套开源的HTML可视化编辑器,主要用于让用户在网站上获得所 ...
- 网络编辑器插件ckeditor+ckfinder配置
原帖地址 另外一个 去掉编辑器的下边栏 在config.js中加入: config.removePlugins = 'elementspath'; config.resize_enabled = fa ...
- CKEditor在线编辑器增加一个自定义插件
CKEditor是一个非常优秀的在线编辑器,它的前身就是FCKEditor,CKEditor据官方说是重写了内核的,但功能和性能比FCKEditor更为强大和优越.记得07年的时候第一次接触FCKEd ...
- MVC5富文本编辑器CKEditor配置CKFinder
富文本编辑器CKEditor的使用 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...
- 在ASP.NET项目中使用CKEditor +CKFinder实现图片上传功能
前言 之前的项目中一直使用的是FCKeditor,昨天突然有个想法:为什么不试一下新的CKEditor呢?于是花了大半天的时间去学习它的用法,现在把我的学习过程与大家分享一下. 谈起FCKeditor ...
随机推荐
- FFMPEG结构体分析:AVCodecContext(转)
注:写了一系列的结构体的分析的文章,在这里列一个列表: FFMPEG结构体分析:AVFrameFFMPEG结构体分析:AVFormatContextFFMPEG结构体分析:AVCodecContext ...
- Ubuntu 16.04 natural scrolling
http://ubuntuhandbook.org/index.php/2016/05/install-ubuntu-tweak-in-ubuntu-16-04/ download ubuntu-tw ...
- vim自定义配置之UI设置
vimConfig/plugin/ui-setting.vim let os = substitute(system('uname'), "\n", "", & ...
- QT win 安装配置
QT windows 版安装配置 安装包:链接:https://pan.baidu.com/s/1LCj2V3xQ1wB9_7zmE5tV6Q 密码:bn9r 首先安装QT Creator 双击安装文 ...
- Windows 10 修改系统环境变量后,CMD生效,Powershell未生效
Windows 10 修改系统环境变量后 1.CMD重新打开,新环境变量已经生效: 2.Shift+右键Powershell重新打开,新环境变量没有生效: 3.貌似服务(Apache24)中使用的环境 ...
- [转][C#]压缩解压缩类 GZipStream
本文来自:https://msdn.microsoft.com/zh-cn/library/system.io.compression.gzipstream(v=vs.100).aspx using ...
- Linux下搭建企业共享目录方案之------samba
Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服务器及客户端程序构成.SMB(Server Messages Block,信息服务块)是一种在局域网上共享文件和打印机的一种通 ...
- 找到一篇关于2.4/5G信道的新介绍
关于部分手机无法搜索到5G wifi信号的解决方法第一次在论坛发基础理论贴,希望能普及关于5G wifi的基础知识. 发此贴的原因是基于本人突然发现:MX3刷了3.4.1系统后,搜索不 ...
- C++实现大正整数及其相关运算(长期更新)
/** 只考虑正数[1, +∞); “-”运算只允许大数减小数; 小端存储: */ typedef struct BigInteger0 { vector<int> v; BigInteg ...
- java8时间使用小结
//LocalDate代表一个IOS格式(yyyy-MM-dd)的日期 获取当前的日期: LocalDate localDate = LocalDate.now();//LocalDate: 表示没有 ...