thinphp 整合ueditor
我的ueditor是部署在public/editor
部署前台页面
<script type="text/javascript" > var UEDITOR_HOME_URL: "__PUBLIC__/ueditor/" </script> <script id="container" name="$des" type="text/plain"> 这里写你的初始化内容 </script> <!-- 配置文件 --> <script type="text/javascript" src="__PUBLIC__/ueditor/ueditor.config.js"></script> <!-- 编辑器源码文件 --> <script type="text/javascript" src="__PUBLIC__/ueditor/ueditor.all.js"></script> <!-- 实例化编辑器 --> <script type="text/javascript"> var ue = UE.getEditor('container',{ autoHeight: false, }); </script>
修改上传配置信息
ueditor所有上传文件的配置都在config.json文件中。
上传路径修改成自己需要的
更改服务器统一入口文件
修改ueditor.config.js文件
统一入口都走public模块的editor 方法。
1 // 服务器统一请求接口路径 2 , serverUrl: "http://localhost/index.php?m=Public&a=editor"
开发一个public 公共的模块
代码我就直接用的ueditor提供的demo。
1 public function getConf(){ 2 $CONFIG = json_decode(preg_replace("/\/\*[\s\S]+?\*\//", "", file_get_contents("public/ueditor/config.json")), true); 3 return $CONFIG; 4 } 5 public function verify(){ 6 import('ORG.Util.Image'); 7 Image::buildImageVerify(); 8 } 9 public function upload(){ 10 import('ORG.Net.UploadFile'); 11 $upload = new UploadFile();// 实例化上传类 12 $upload->maxSize = 1024*1024 ;// 设置附件上传大小 13 $upload->thumb=true; 14 $upload->thumbMaxWidth='150,100'; 15 $upload->thumbMaxHeight='150,50'; 16 $upload->thumbPrefix="mid_,small_"; 17 $upload->autoSub=true; 18 $upload->subType=date; 19 $upload->dateFormat='Ymd'; 20 $upload->allowExts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型 21 $upload->savePath = './Public/Uploads/';// 设置附件上传目录 22 if(!$upload->upload()) {// 上传错误提示错误信息 23 $this->error($upload->getErrorMsg()); 24 }else{// 上传成功 获取上传文件信息 25 $info = $upload->getUploadFileInfo(); 26 return $info; 27 } 28 } 29 30 public function action_list(){ 31 $CONFIG=$this->getConf(); 32 /* 判断类型 */ 33 switch ($_GET['action']) { 34 /* 列出文件 */ 35 case 'listfile': 36 $allowFiles = $CONFIG['fileManagerAllowFiles']; 37 $listSize = $CONFIG['fileManagerListSize']; 38 $path = $CONFIG['fileManagerListPath']; 39 break; 40 /* 列出图片 */ 41 case 'listimage': 42 default: 43 $allowFiles = $CONFIG['imageManagerAllowFiles']; 44 $listSize = $CONFIG['imageManagerListSize']; 45 $path = $CONFIG['imageManagerListPath']; 46 } 47 $allowFiles = substr(str_replace(".", "|", join("", $allowFiles)), 1); 48 49 /* 获取参数 */ 50 $size = isset($_GET['size']) ? htmlspecialchars($_GET['size']) : $listSize; 51 $start = isset($_GET['start']) ? htmlspecialchars($_GET['start']) : 0; 52 $end = $start + $size; 53 54 /* 获取文件列表 */ 55 $path = $_SERVER['DOCUMENT_ROOT'] . (substr($path, 0, 1) == "/" ? "":"/") . $path; 56 $files = getfiles($path, $allowFiles); 57 if (!count($files)) { 58 return json_encode(array( 59 "state" => "no match file", 60 "list" => array(), 61 "start" => $start, 62 "total" => count($files) 63 )); 64 } 65 66 /* 获取指定范围的列表 */ 67 $len = count($files); 68 for ($i = min($end, $len) - 1, $list = array(); $i < $len && $i >= 0 && $i >= $start; $i--){ 69 $list[] = $files[$i]; 70 } 71 //倒序 72 //for ($i = $end, $list = array(); $i < $len && $i < $end; $i++){ 73 // $list[] = $files[$i]; 74 //} 75 76 /* 返回数据 */ 77 $result = json_encode(array( 78 "state" => "SUCCESS", 79 "list" => $list, 80 "start" => $start, 81 "total" => count($files) 82 )); 83 84 return $result; 85 86 } 87 public function action_upload(){ 88 import('ORG.Net.Uploader'); 89 $CONFIG=$this->getConf(); 90 /* 上传配置 */ 91 $base64 = "upload"; 92 switch (htmlspecialchars($_GET['action'])) { 93 case 'uploadimage': 94 $config = array( 95 "pathFormat" => $CONFIG['imagePathFormat'], 96 "maxSize" => $CONFIG['imageMaxSize'], 97 "allowFiles" => $CONFIG['imageAllowFiles'] 98 ); 99 $fieldName = $CONFIG['imageFieldName']; 100 break; 101 case 'uploadscrawl': 102 $config = array( 103 "pathFormat" => $CONFIG['scrawlPathFormat'], 104 "maxSize" => $CONFIG['scrawlMaxSize'], 105 "allowFiles" => $CONFIG['scrawlAllowFiles'], 106 "oriName" => "scrawl.png" 107 ); 108 $fieldName = $CONFIG['scrawlFieldName']; 109 $base64 = "base64"; 110 break; 111 case 'uploadvideo': 112 $config = array( 113 "pathFormat" => $CONFIG['videoPathFormat'], 114 "maxSize" => $CONFIG['videoMaxSize'], 115 "allowFiles" => $CONFIG['videoAllowFiles'] 116 ); 117 $fieldName = $CONFIG['videoFieldName']; 118 break; 119 case 'uploadfile': 120 default: 121 $config = array( 122 "pathFormat" => $CONFIG['filePathFormat'], 123 "maxSize" => $CONFIG['fileMaxSize'], 124 "allowFiles" => $CONFIG['fileAllowFiles'] 125 ); 126 $fieldName = $CONFIG['fileFieldName']; 127 break; 128 } 129 130 /* 生成上传实例对象并完成上传 */ 131 $up = new Uploader($fieldName, $config, $base64); 132 133 /** 134 * 得到上传文件所对应的各个参数,数组结构 135 * array( 136 * "state" => "", //上传状态,上传成功时必须返回"SUCCESS" 137 * "url" => "", //返回的地址 138 * "title" => "", //新文件名 139 * "original" => "", //原始文件名 140 * "type" => "" //文件类型 141 * "size" => "", //文件大小 142 * ) 143 */ 144 145 /* 返回数据 */ 146 return json_encode($up->getFileInfo()); 147 148 } 149 /** 150 * 编辑器 151 */ 152 public function editor(){ 153 $CONFIG = $this->getConf(); 154 $action = $_GET['action']; 155 156 switch ($action) { 157 case 'config': 158 $result = json_encode($CONFIG); 159 break; 160 161 /* 上传图片 */ 162 case 'uploadimage': 163 /* 上传涂鸦 */ 164 case 'uploadscrawl': 165 /* 上传视频 */ 166 case 'uploadvideo': 167 /* 上传文件 */ 168 case 'uploadfile': 169 $result = $this->action_upload(); 170 break; 171 172 /* 列出图片 */ 173 case 'listimage': 174 $result =$this-> action_list(); 175 break; 176 /* 列出文件 */ 177 case 'listfile': 178 $result = $this-> action_list(); 179 break; 180 181 /* 抓取远程文件 */ 182 case 'catchimage': 183 $result = $this-> action_crawler(); 184 break; 185 186 default: 187 $result = json_encode(array( 188 'state'=> '请求地址出错' 189 )); 190 break; 191 } 192 193 /* 输出结果 */ 194 if (isset($_GET["callback"])) { 195 if (preg_match("/^[\w_]+$/", $_GET["callback"])) { 196 //echo htmlspecialchars($_GET["callback"]) . '(' . $result . ')'; 197 //echo ($_GET["callback"]) . '(' . $result . ')'; 198 die(($_GET["callback"]) . '(' . $result . ')'); 199 } else { 200 echo json_encode(array( 201 'state'=> 'callback参数不合法' 202 )); 203 } 204 } else { 205 echo $result; 206 } 207 } 208 /** 209 * 上传抓图 210 */ 211 public function action_crawler(){ 212 import('ORG.Net.Uploader'); 213 $CONFIG=$this->getConf(); 214 /* 上传配置 */ 215 $config = array( 216 "pathFormat" => $CONFIG['catcherPathFormat'], 217 "maxSize" => $CONFIG['catcherMaxSize'], 218 "allowFiles" => $CONFIG['catcherAllowFiles'], 219 "oriName" => "remote.png" 220 ); 221 $fieldName = $CONFIG['catcherFieldName']; 222 223 /* 抓取远程图片 */ 224 $list = array(); 225 if (isset($_POST[$fieldName])) { 226 $source = $_POST[$fieldName]; 227 } else { 228 $source = $_GET[$fieldName]; 229 } 230 foreach ($source as $imgUrl) { 231 $item = new Uploader($imgUrl, $config, "remote"); 232 $info = $item->getFileInfo(); 233 array_push($list, array( 234 "state" => $info["state"], 235 "url" => $info["url"], 236 "size" => $info["size"], 237 "title" => htmlspecialchars($info["title"]), 238 "original" => htmlspecialchars($info["original"]), 239 "source" => htmlspecialchars($imgUrl) 240 )); 241 } 242 243 /* 返回抓取数据 */ 244 return json_encode(array( 245 'state'=> count($list) ? 'SUCCESS':'ERROR', 246 'list'=> $list 247 )); 248 }
控制器接收数据
要使用htmlspecialchars_decode把一些预定义的 HTML 实体转换为字符
1 $data['des']=htmlspecialchars_decode($this->_post('des'));