Thinkphp 3.2.3配置百度编辑器(UEditor)

1、把百度编辑器放到项目的Public目录下 命名为:UEditor

2、找到thinkphp框架系统自带类中的Html.class.php,并且添加在switch(strtoupper($type)) {}中添加代码

case 'UEDITOR':

$parseStr   =  "\n".'<script type="text/javascript" charset="utf-8"

src="__ROOT__/Public/UEditor/ueditor.config.js"></script>'."\n".'

<script type="text/javascript" charset="utf-8"

src="__ROOT__/Public/UEditor/ueditor.all.js"></script>'."\n".'

<script type="text/plain" id="'.$id.'" name="'.$name.'" style="'

.$style.'">'.$content.'</script>'."\n".'<script type="text/javascript">var ue_'.$id.' = UE.getEditor("'.$id.'");</script>'."\n";

break;

3. 在项目文件的www/myproject/Application/Admin/Conf目录下新建ueditconfig.json文件,

4. 把ueditor源码的php文件夹下的config.json中的内容复制到ueditconfig.json文件中

5.在百度编辑器目录的ueditor.config.js文件内修改:(好像可以省略)

// 服务器统一请求接口路径

, serverUrl: URL + "../../index.php/Home/Index/ueditup"

6. 就是你需要的用TP自带上传类处理上传了,在Home模块的Index控制器里加上下面的方法:

public function ueditup(){

header("Content-Type: text/html; charset=utf-8");

$editconfig = json_decode(preg_replace("/\/\*[\s\S]+?\*\//", "", file_get_contents(COMMON_PATH."Conf/ueditconfig.json")), true);

//dump($editconfig);

$action = I('get.action');

//echo $action;

switch ($action) {

case 'config':

$result =  json_encode($editconfig);

break;

/* 上传图片 */

case 'uploadimage':

$result = $this->editup('img');

break;

/* 上传涂鸦 */

case 'uploadscrawl':

$result = $this->editup('img');

break;

case 'uploadvideo':

$result = $this->editup('video');

break;

case 'uploadfile':

$result = $this->editup('file');

//$result = include("action_upload.php");

break;

/* 列出图片 */

case 'listimage':

$result = $this->editlist('listimg');

break;

/* 列出文件 */

case 'listfile':

$result = $this->editlist('listfile');

break;

/* 抓取远程文件 */

case 'catchimage':

//$result = include("action_crawler.php");

break;

default:

$result = json_encode(array(

'state'=> '请求地址出错'

));

break;

}

/* 输出结果 */

if (isset($_GET["callback"])) {

if (preg_match("/^[\w_]+$/", $_GET["callback"])) {

echo htmlspecialchars($_GET["callback"]) . '(' . $result . ')';

} else {

echo json_encode(array(

'state'=> 'callback参数不合法'

));

}

} else {

echo $result;

}

}

public function editup($uptype){

if($this->islogin==false){

$_re_data['state'] = '请登陆';

return json_encode($_re_data);

}

$editconfig = json_decode(preg_replace("/\/\*[\s\S]+?\*\//", "", file_get_contents(COMMON_PATH."Conf/ueditconfig.json")), true);

switch ($uptype) {

case 'img':

$upload = new \Think\Upload();// 实例化上传类

$upload->rootPath  =     '.';

$upload->maxSize   =     $editconfig['imageMaxSize'];

$upload->exts      =     explode('.', trim(join('',$editconfig['imageAllowFiles']),'.'));

$upload->savePath  =     $editconfig['imagePathFormat'];

$upload->saveName  =     time().rand(100000,999999);

$info   =   $upload->uploadOne($_FILES[$editconfig['imageFieldName']]);

break;

case 'file':

$upload = new \Think\Upload();// 实例化上传类

$upload->rootPath  =     '.';

$upload->maxSize   =     $editconfig['fileMaxSize'];

$upload->exts      =     explode('.', trim(join('',$editconfig['fileAllowFiles']),'.'));

$upload->savePath  =     $editconfig['filePathFormat'];

$upload->saveName  =     time().rand(100000,999999);

$info   =   $upload->uploadOne($_FILES[$editconfig['fileFieldName']]);

break;

case 'video':

$upload = new \Think\Upload();// 实例化上传类

$upload->rootPath  =     '.';

$upload->maxSize   =     $editconfig['videoMaxSize'];

$upload->exts      =     explode('.', trim(join('',$editconfig['videoAllowFiles']),'.'));

$upload->savePath  =     $editconfig['videoPathFormat'];

$upload->saveName  =     time().rand(100000,999999);

$info   =   $upload->uploadOne($_FILES[$editconfig['videoFieldName']]);

break;

default:

return false;

break;

}

if(!$info) {// 上传错误提示错误信息

$_re_data['state'] = $upload->getError();

$_re_data['url'] = '';

$_re_data['title'] = '';

$_re_data['original'] = '';

$_re_data['type'] = '';

$_re_data['size'] = '';

}else{// 上传成功 获取上传文件信息

$_re_data['state'] = 'SUCCESS';

$_re_data['url'] = $info['savepath'].$info['savename'];

$_re_data['title'] = $info['savename'];

$_re_data['original'] = $info['name'];

$_re_data['type'] = '.'.$info['ext'];

$_re_data['size'] = $info['size'];

}

return json_encode($_re_data);

}

public function editlist($listtype){

$editconfig = json_decode(preg_replace("/\/\*[\s\S]+?\*\//", "", file_get_contents(COMMON_PATH."Conf/ueditconfig.json")), true);

switch ($listtype) {

case 'listimg':

$allowFiles = $editconfig['imageManagerAllowFiles'];

$listSize = $editconfig['imageManagerListSize'];

$path = $editconfig['imageManagerListPath'];

break;

case 'listfile':

$allowFiles = $editconfig['fileManagerAllowFiles'];

$listSize = $editconfig['fileManagerListSize'];

$path = $editconfig['fileManagerListPath'];

break;

default:

return false;

break;

}

/* 获取参数 */

$size = isset($_GET['size']) ? htmlspecialchars($_GET['size']) : $listSize;

$start = isset($_GET['start']) ? htmlspecialchars($_GET['start']) : 0;

$end = $start + $size;

/* 获取文件列表 */

$path = $_SERVER['DOCUMENT_ROOT'] . (substr($path, 0, 1) == "/" ? "":"/") . $path;

$files = $this->getfiles($path, $allowFiles);

if (!count($files)) {

return json_encode(array(

"state" => "no match file",

"list" => array(),

"start" => $start,

"total" => count($files)

));

}

/* 获取指定范围的列表 */

$len = count($files);

for ($i = min($end, $len) - 1, $list = array(); $i < $len && $i >= 0 && $i >= $start; $i--){

$list[] = $files[$i];

}

//倒序

//for ($i = $end, $list = array(); $i < $len && $i < $end; $i++){

//    $list[] = $files[$i];

//}

/* 返回数据 */

$result = json_encode(array(

"state" => "SUCCESS",

"list" => $list,

"start" => $start,

"total" => count($files)

));

return $result;

}

/**

* 遍历获取目录下的指定类型的文件

* @param $path

* @param array $files

* @return array

*/

public function getfiles($path, $allowFiles, &$files = array())

{

if (!is_dir($path)) return null;

if(substr($path, strlen($path) - 1) != '/') $path .= '/';

$handle = opendir($path);

while (false !== ($file = readdir($handle))) {

if ($file != '.' && $file != '..') {

$path2 = $path . $file;

if (is_dir($path2)) {

$this->getfiles($path2, $allowFiles, $files);

} else {

if(in_array('.'.pathinfo($file, PATHINFO_EXTENSION), $allowFiles)){

$files[] = array(

'url'=> substr($path2, strlen($_SERVER['DOCUMENT_ROOT'])),

'mtime'=> filemtime($path2)

);

}

}

}

}

return $files;

}

(7.8在一个页面进行)

7. 在需要用到编辑器的模板head内加上: (哪里需要它就就调用)

<taglib name="html" />

8. 在用到编辑器的地方加上:(哪里需要它就就调用)

<html:editor id="info" name="info" type="UEDITOR" >{$info.info}</html:editor>

综上效果

补充:使用UEDITOR存在数据库的资料带有标签和样式

当我们打印值的时候会出现如下情况(需要)

<{:htmlspecialchars_decode($xx['xx'])}>

Thinkphp 3.2.3配置百度编辑器(UEditor)的更多相关文章

  1. 关于百度编辑器UEditor的一点说明

    大家在使用的时候要特别注意editor_config.js中的“URL”这个参数 我的理解:1.这个参数是editor整个结构的总路径          2.首先要把这个路径配置好了.才能正常的显示, ...

  2. [转载]百度编辑器-Ueditor使用

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

  3. 百度编辑器 ueditor .net开发

    ueditor1.4.3 下载地址:http://pan.baidu.com/s/1bnCQVtd   <!--editor--> <script type="text/j ...

  4. drupal7 安装百度编辑器Ueditor及后续使用

    参考文章:drupal7安装百度编辑器ueditor 一.下载 1.需要下载安装的模块: 1.1.wysiwyg 1.2.ueditor 1.3Libraries 下载后安装在\sites\all\m ...

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

    在使用百度编辑器ueditor的时候,怎么将图片保存到另一个服务器,或者上传到ftp服务器?这个问题,估计很多使用UE的人会遇到.而且我百度过,没有找到这个问题的解决方案.那么:本篇文章就很适合你了. ...

  6. 百度编辑器UEditor,保存图片的配置问题

    前言: 在使用百度编辑器UEditor的时候,如何将图片保存到服务器,我刚开始以为是要自己写上传文件的方法,后来发现只需要配置一下即可,如果你也正在使用百度富文本编辑器UEditor的话,这篇文章将非 ...

  7. 百度编辑器ueditor插入表格没有边框颜色的解决方法

    附:从word excel 中 复制的表格提交后无边框,参考这个同学的,写的很详细:   http://blog.csdn.net/lovelyelfpop/article/details/51678 ...

  8. 百度编辑器ueditor插入表格没有边框,没有颜色的解决方法 2015-01-06 09:24 98人阅读 评论(0) 收藏

    百度富文本编辑器..很强大.. - - ,不过有些BUG..真的很无解.. 最近用这个,发现上传的表格全部没有表框.. 解决办法如下: 转载的.. 百度编辑器ueditor插入一个表格后,在编辑过程中 ...

  9. 百度编辑器ueditor 异步加载时,初始化没办法赋值bug解决方法

    百度编辑器ueditor 异步加载时,初始化没办法赋值bug解决方法 金刚 前端 ueditor 初始化 因项目中使用了百度编辑器——ueditor.整体来说性能还不错. 发现问题 我在做一个编辑页面 ...

随机推荐

  1. 曲演杂坛--重建索引后,还使用混合分区么?(Are mixed pages removed by an index rebuild?)

    原文来自:http://www.sqlskills.com/blogs/paul/mixed-pages-removed-index-rebuild/ 在SQL SERVER 中,区是管理空间的基本单 ...

  2. 各种方法配置 Visual Studio 第三方库

    配置第三方库如Opencv,或者软件开发商提供的SDK时,一般需要配置三个文件: 头文件(.h),引入库(.lib)文件(也称“导入库文件”),动态链接库(.dll)文件 下面以度申科技的相机sdk配 ...

  3. VisualStudio神级插件——JetBrains Resharper 2018.2.3 Ultimate完美破解版+教程

    ReSharper是一个JetBrains公司出品的著名的代码生成工具,是Visual Studio里面的一个插件.它包括一系列丰富的能大大增加C#和Visual Basic .NET开发者生产力的特 ...

  4. wpf 右下角弹出窗

    自己写的wpf 弹出框,欢迎拍砖,动画都写在了后台代码,前台代码不太重要,用了一下iconfont,具体样式我就不贴出来了,本次主要是后台代码的动画 需要有父级窗口才可以使用. 前台代码: <W ...

  5. 《JavaScript模式》一书中提到的一些坑

    1. 应当用数组字面量来创建数组,而不是用new Array() //反模式 var a = new Array('itsy', 'bitsy', 'spider'); //用字面量 var a = ...

  6. 弦论(tjoi2015,bzoj3998)(sam(后缀自动机))

    对于一个给定长度为\(N\)的字符串,求它的第\(K\)小子串是什么. Input 第一行是一个仅由小写英文字母构成的字符串\(S\) 第二行为两个整数\(T\)和\(K\),\(T\)为0则表示不同 ...

  7. jzoj5805

    #include<bits/stdc++.h> using namespace std; int x,n,pp,ct[10000]; long double f[210][(1<&l ...

  8. jzoj5804

    這道題n-m很小,可以從此入手 記f[i][j]為i個字符括號綜合為j的合法方案數 則第i個括號可以枚舉為(和),所以f[i][j]=f[i-1][j-1]+f[i-1][j+1],小心越界 再記a為 ...

  9. JavaScript基础事件(6)

    day53 参考:https://www.cnblogs.com/liwenzhou/p/8011504.html#autoid-2-3-8 事件 HTML 4.0 的新特性之一是有能力使 HTML ...

  10. powerDesiner设计数据库的一些用法

    数据库的设计主要有以下几个步骤: 1:需求分析:根据业务需求分析出满足客户的需求,从而建立相应的数据库 2:概念设计:通过数据抽象,设计系统概念模型,一般为E-R模型:(entity-relation ...