thinphp 整合ueditor

個人ueditor是部署在public/editorjavascript

部署前臺頁面

<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文件中。php

上傳路徑修改爲本身須要的html

更改服務器統一入口文件

修改ueditor.config.js文件java

統一入口都走public模塊的editor 方法。json

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'));
相關文章
相關標籤/搜索