百度ueditor的圖片上傳,先後端交互使用

百度ueditor的使用javascript

  一個文本編輯器,看了網上不少文檔寫的很亂,這裏拾人牙慧,整理下怎麼使用。php

這個東西若是不涉及到圖片附件上傳,其實很簡單,就是幾個前端文件,直接引用,而後配置下ueditor.config.js便可。這裏就很少說。html

至於圖片上傳,ueditor 設計的時候是考慮和後端交互的,因此會看到能夠下載什麼php,java版本,還有不少網上會說道有什麼後端配置文件,改那改這的,可是實際上後端存儲業務是按照公司實際來的,實踐起來並不順利。前端

本文重點講述的只用前端文件和ueditor.all.js、ueditor.config.js,若是來實踐和後端交互,圖片上傳。java

 

(步驟1)下載文件,文件目錄以下,圖中的php (java、net)刪掉,咱們不須要提供的後端文件。主要會調整到ueditor.all.js,ueditor.config.jsajax

 

 

(步驟2) 而後參考官網 在頁面放以下的html和js引用,以下。這是頁面就能顯示編輯器了,工具欄的內容在ueditor.config.js的toolbars配置json

<!DOCTYPE HTML> <html lang="en-US"> 
<head> <meta charset="UTF-8">
  <title>ueditor demo</title>
</head>
<body> <!-- 加載編輯器的容器 -->
<script id="container" name="content" type="text/plain"> 這裏寫你的初始化內容 </script> <!-- 配置文件 -->
<script type="text/javascript" src="ueditor.config.js"></script> <!-- 編輯器源碼文件 -->
<script type="text/javascript" src="ueditor.all.js"></script> <!-- 實例化編輯器 -->
<script type="text/javascript"> var ue = UE.getEditor('container'); </script> </body> </html>

保存和修改,就經過js獲取編輯器的內容,再ajax請求或form表單了。後端

//獲取html內容,返回: <p>hello</p> 

var html = ue.getContent();
var html = ue.setContent(); 

//獲取純文本內容,返回: hello

var txt = ue.getContentTxt();

(步驟3) 後端交互(重點)瀏覽器

  到這裏,若是還想圖片文件上傳,就會遇到一個問題,瀏覽器會報錯,顯示ueditor 後端配置項沒有正常加載,上傳插件不能正常使用。這個是由於ueditor加載後,會去請求後端,拿後端的配置項。tomcat

  咱們還沒處理後端邏輯,天然會報錯。

  ueditor給咱們提供了一個請求URL配置,惟一和後端交互的地址,全部向後端的請求只有這個。就是ueditor.config.js裏面的serverUrl。

  可是若是咱們有多個請求action事務呢,ueditor自己的設計是咱們能夠經過 http://serverUrl?action=actionA/actiongB. 在後端本身去分發action,上面的加載後端配置,請求就是=//serverUrl?action=config。

  咱們按照這個思路來寫後端,也能夠在前端轉發請求給不一樣的後端接口。下面講下這2種如何實現

 

一、經過惟一serverUrl接口,在後端分發aciton

先在ueditor.config.js配置下面參數

serverUrl:/ueditorEdit/eventHandler //惟一和後端交互的接口地址

imageActionName: /uploadimage //配置上傳圖片的action,沒有配置的話,有默認值uploadimage

在後端函數eventHandler裏,根據request的action參數作分發。

組件默認有哪些action,具體action的狀況能夠參考ueditor.all.js源碼 8006行,源碼以下

/**
         * 根據action名稱獲取請求的路徑
         * @method  getActionUrl
         * @remind 假如沒有設置serverUrl,會根據imageUrl設置默認的controller路徑
         * @param { String } action action名稱
         * @example
         * ```javascript
         * editor.getActionUrl('config'); //返回 "/ueditor/php/controller.php?action=config"
         * editor.getActionUrl('image'); //返回 "/ueditor/php/controller.php?action=uplaodimage"
         * editor.getActionUrl('scrawl'); //返回 "/ueditor/php/controller.php?action=uplaodscrawl"
         * editor.getActionUrl('imageManager'); //返回 "/ueditor/php/controller.php?action=listimage"
         * ```
         */
        getActionUrl: function(action){
            var actionName = this.getOpt(action) || action,
                imageUrl = this.getOpt('imageUrl'),
                serverUrl = this.getOpt('serverUrl');

            if(!serverUrl && imageUrl) {
                serverUrl = imageUrl.replace(/^(.*[\/]).+([\.].+)$/, '$1controller$2');
            }

            if(serverUrl) {
                serverUrl = serverUrl + (serverUrl.indexOf('?') == -1 ? '?':'&') + 'action=' + (actionName || '');
                return utils.formatUrl(serverUrl);
            } else {
                return '';
            }
        }

  在後端eventHandler,接收到請求的aciton=config 時,就是獲取後端配置。因爲咱們並無使用後端配置,因此這裏返回了 {state:」配置文件初始化失敗「},以下圖,這樣改就能解決前端報後端配置項沒有正常加載的問題固然這裏你能夠本身封裝返回結果(基本各自的框架都會對結果進行封裝),只要前端相應修改。java後端代碼以下

@RequestMapping("/eventHandler")

public void eventHandler(HttpServletRequest request, HttpServletResponse response) throws IOException {

  //action==config加載後端配置處理

  if(request.getParameter("action").equals("config")){

    request.setCharacterEncoding( "utf-8" );

    response.setHeader("Content-Type" , "text/html");
  
    // 返回 {state: "配置文件初始化失敗"}

    //這裏沒有用ueditor的後端jar和後端配置,上傳的接口都是另外寫的。只需ueditor的前端文件便可

    //若是要使用ueditor的後端配置,須要把後端配置文件放到tomcat的根目錄或者指定目錄

    // 加載後端配置文件的js是ueditor.all.js的UE.Editor.prototype.loadServerConfig,能夠直接在前端禁掉js加載後端配置的請求

    response.getWriter().write("{\"state\": \"\\u914d\\u7f6e\\u6587\\u4ef6\\u521d\\u59cb\\u5316\\u5931\\u8d25\"}");

  }

}

返回後,ueditor前端怎麼處理呢,能夠看下在ueditor.all.js 8088行的源碼,以下。

       configUrl && UE.ajax.request(configUrl,{
                    'method': 'GET',
                    'dataType': isJsonp ? 'jsonp':'',
                    'onsuccess':function(r){
                        try {
                            var config = isJsonp ? r:eval("("+r.responseText+")");
                            utils.extend(me.options, config);
                            me.fireEvent('serverConfigLoaded');
                            me._serverConfigLoaded = true;
                        } catch (e) {
                            showErrorMsg(me.getLang('loadconfigFormatError'));
                        }
                    },
                    'onerror':function(){
                        showErrorMsg(me.getLang('loadconfigHttpError'));
                    }
                });

解決完配置加載問題後,至於圖片上傳,就在eventHandler裏面判斷action=uploadimage 裏面本身去處理上傳邏輯,前端返回處理在ueditor.all.js 的24520,根據本身返回的結果調整下js腳本,以下,調整過的腳本

try{
                        var link, json, loader,
                            body = (iframe.contentDocument || iframe.contentWindow.document).body,
                            result = body.innerText || body.textContent || '';
                        json = (new Function("return " + result))();
                        //link = me.options.imageUrlPrefix + json.url;
                        //if(json.state == 'SUCCESS' && json.url) {
                        //    loader = me.document.getElementById(loadingId);
                        //    loader.setAttribute('src', link);
                        //    loader.setAttribute('_src', link);
                        //    loader.setAttribute('title', json.title || '');
                        //    loader.setAttribute('alt', json.original || '');
                        //    loader.removeAttribute('id');
                        //    domUtils.removeClasses(loader, 'loadingclass');
                        //} else {
                        //    showErrorLoader && showErrorLoader(json.state);
                        //}
                        if(json.success && json.result){
                            loader = me.document.getElementById(loadingId);
                            loader.setAttribute('src', json.result);
                            loader.setAttribute('_src', json.result);
                            loader.setAttribute('title', json.title || '');
                            loader.setAttribute('alt', json.original || '');
                            loader.removeAttribute('id');
                            domUtils.removeClasses(loader, 'loadingclass');
                        }else{
                            showErrorLoader && showErrorLoader(json.success);
                        }
                    }catch(er){
                        showErrorLoader && showErrorLoader(me.getLang('simpleupload.loadError'));
                    }

二、經過不一樣的接口對應不一樣的action

ueditor.config.js配置以下

serverUrl: "/xxx/loadConfig" //加載配置,後端返回失敗

imageActionName:"/xxx/uploadImage" //上傳圖片,前端轉發

而後咱們把惟一的接口serverUrl當成加載配置的接口,上面的代碼中就不須要判斷action=config了,直接返回{state:」配置文件初始化失敗「},便可。

@RequestMapping("/eventHandler")

public void eventHandler(HttpServletRequest request, HttpServletResponse response) throws IOException {

  request.setCharacterEncoding( "utf-8" );

  response.setHeader("Content-Type" , "text/html");

  response.getWriter().write("{\"state\": \"\\u914d\\u7f6e\\u6587\\u4ef6\\u521d\\u59cb\\u5316\\u5931\\u8d25\"}");

}

最後在前端轉發圖片上傳接口,在咱們引用ueditor組件的前端頁面上,重寫UE.Editor.prototype.getActionUrl 函數,函數源碼在ueditor.all.js,能夠本身去看. 重寫轉發以下,若是action=/xxx/uploadImage,直接請求/xxx/uploadImage

<script>

var ue = UE.getEditor('editor');

UE.Editor.prototype._bkGetActionUrl = UE.Editor.prototype.getActionUrl;

UE.Editor.prototype.getActionUrl =function(action){

//若是ation =圖片上傳,直接調用圖片上傳的接口

if(action == '/xxx/uploadImage'){

  return '/xxx/uploadImage';

}else {

  return this._bkGetActionUrl.call(this,action);

}

};

</script>

這樣圖片上傳就會直接調用/xxx/uploadImage接口,而不影響serverUrl配置,圖片上傳後返回,也是在ueditor.all.js 的24525行進行調整

總結,這篇文章重在說明先後端交互調整的思路,具體如何實現,要按照本身的實際狀況來使用。後端具體的存儲業務看各自的處理方式,可是咱們要作的就是保存物理文件,拿回物理文件的地址。

相關文章
相關標籤/搜索