springboot整合uedior上傳文件至ftp(前後端分離項目)

1、下載ueditor完整源碼包:https://ueditor.baidu.com/website/download.html
解壓之後進入jsp文件夾,文件結構如下:
在這裏插入圖片描述
2、將src文件夾下的文件複製到spingboot項目中,將config.json文件複製到項目的resources文件夾下,導入lib文件夾中相關的jar包。
3、新建一個接口,用於ueditor獲取config.json文件及上傳文件至ftp

@RestController
@CrossOrigin
@RequestMapping("api/ueditor")
@Slf4j
public class UeditorController {

	@RequestMapping(value="/exec", method={RequestMethod.GET, RequestMethod.POST})
	public void exec(HttpServletRequest request, HttpServletResponse response) throws UnsupportedEncodingException {

		request.setCharacterEncoding("utf-8");
		if("config".equals(request.getParameter("action"))){
		//讀取config.json配置文件
			response.setContentType("application/javascript");
		}else {
		//上傳文件
			response.setContentType("text/html");
		}
		String rootPath = ClassUtils.getDefaultClassLoader().getResource("").getPath();
		try {
			response.getWriter().write(new ActionEnter(request, rootPath).exec());
		} catch (IOException e) {
			log.error("ueditor訪問失敗", e);
		}

	}
}

4、將前端代碼ueditor.config.js中的serverUrl設置爲上述接口的訪問地址。
5、拿上傳圖片爲例:
將config.json這兩項進行修改:
“imageUrlPrefix”: “/project/api/ueditor/show?path=”, /* 圖片訪問路徑前綴 ,顯示圖片時調用的接口*/
“imagePathFormat”: “dev/project/{yyyy}{mm}{dd}/{filename}”, /* 上傳保存路徑,可以自定義保存路徑和文件名格式 */
6、修改BinaryUploader類中的save方法中讀取文件的代碼:

FileItemIterator iterator = upload.getItemIterator(request);

   		while (iterator.hasNext()) {
   			fileStream = iterator.next();

   			if (!fileStream.isFormField())
   				break;
   			fileStream = null;
   		}

替換爲如下的代碼:(上述的方式不知道爲什麼在springboot中會讀不到文件,好像是的包衝突,springboot自帶的MultipartFile與上述文件導的包有衝突)

  Part file = null;
  Collection<Part> parts = request.getParts();
      if(CollectionUtils.isEmpty(parts)){
        return new BaseState(false, 7);
      }
      Iterator<Part> iterator = parts.iterator();
      while (iterator.hasNext()){
        file = iterator.next();
        break;
      }

7、修改StorageManager類中的saveTmpFile方法,在此方法中填寫上傳至Ftp的業務,上傳成功之後記得刪除臨時文件。
可在此方法結束時,設置返回的url:

state.putInfo("url", PathFormat.format(pathname +filename));

8、圖片回顯:
回顯圖片時,前端後訪問config.json文件中imageUrlPrefix對應的接口,此時在上述controller中寫一個接口如下:

   @RequestMapping(value="/show")
	public byte[]  show(@RequestParam("path") String path, HttpServletResponse response) throws IOException{
		InputStream inputStream = FtpUtil.downloadFile(path);
		String prexi = path.substring(path.lastIndexOf(".")+1);
		//根據文件後綴,設置不同的contentType
		String contentType = getContentType(prexi);
		response.setContentType(contentType);
		byte[] bytes = new byte[inputStream.available()];
		inputStream.read(bytes, 0, inputStream.available());
		return bytes;
	}

private static String getContentType(String fileextname)
	{
		switch (fileextname)
		{
			case "jpeg": return "image/jpeg";
			case "jpg": return "image/jpeg";
			case "js": return "application/x-javascript";
			case "jsp": return "text/html";
			case "gif": return "image/gif";
			case "htm": return "text/html";
			case "html": return "text/html";
			case "asf": return "video/x-ms-asf";
			case "avi": return "video/avi";
			case "bmp": return "application/x-bmp";
			case "asp": return "text/asp";
			case "wma": return "audio/x-ms-wma";
			case "wav": return "audio/wav";
			case "wmv": return "video/x-ms-wmv";
			case "ra": return "audio/vnd.rn-realaudio";
			case "ram": return "audio/x-pn-realaudio";
			case "rm": return "application/vnd.rn-realmedia";
			case "rmvb": return "application/vnd.rn-realmedia-vbr";
			case "xhtml": return "text/html";
			case "png": return "image/png";
			case "ppt": return "application/x-ppt";
			case "tif": return "image/tiff";
			case "tiff": return "image/tiff";
			case "xls": return "application/x-xls";
			case "xlw": return "application/x-xlw";
			case "xml": return "text/xml";
			case "xpl": return "audio/scpls";
			case "swf": return "application/x-shockwave-flash";
			case "torrent": return "application/x-bittorrent";
			case "dll": return "application/x-msdownload";
			case "asa": return "text/asa";
			case "asx": return "video/x-ms-asf";
			case "au": return "audio/basic";
			case "css": return "text/css";
			case "doc": return "application/msword";
			case "exe": return "application/x-msdownload";
			case "mp1": return "audio/mp1";
			case "mp2": return "audio/mp2";
			case "mp2v": return "video/mpeg";
			case "mp3": return "audio/mp3";
			case "mp4": return "video/mpeg4";
			case "mpa": return "video/x-mpg";
			case "mpd": return "application/vnd.ms-project";
			case "mpe": return "video/x-mpeg";
			case "mpeg": return "video/mpg";
			case "mpg": return "video/mpg";
			case "mpga": return "audio/rn-mpeg";
			case "mpp": return "application/vnd.ms-project";
			case "mps": return "video/x-mpeg";
			case "mpt": return "application/vnd.ms-project";
			case "mpv": return "video/mpg";
			case "mpv2": return "video/mpeg";
			case "wml": return "text/vnd.wap.wml";
			case "wsdl": return "text/xml";
			case "xsd": return "text/xml";
			case "xsl": return "text/xml";
			case "xslt": return "text/xml";
			case "htc": return "text/x-component";
			case "mdb": return "application/msaccess";
			case "zip": return "application/zip";
			case "rar": return "application/x-rar-compressed";
			case "*": return "application/octet-stream";
			case "001": return "application/x-001";
			case "301": return "application/x-301";
			case "323": return "text/h323";
			case "906": return "application/x-906";
			case "907": return "drawing/907";
			case "a11": return "application/x-a11";
			case "acp": return "audio/x-mei-aac";
			case "ai": return "application/postscript";
			case "aif": return "audio/aiff";
			case "aifc": return "audio/aiff";
			case "aiff": return "audio/aiff";
			case "anv": return "application/x-anv";
			case "awf": return "application/vnd.adobe.workflow";
			case "biz": return "text/xml";
			case "bot": return "application/x-bot";
			case "c4t": return "application/x-c4t";
			case "c90": return "application/x-c90";
			case "cal": return "application/x-cals";
			case "cat": return "application/vnd.ms-pki.seccat";
			case "cdf": return "application/x-netcdf";
			case "cdr": return "application/x-cdr";
			case "cel": return "application/x-cel";
			case "cer": return "application/x-x509-ca-cert";
			case "cg4": return "application/x-g4";
			case "cgm": return "application/x-cgm";
			case "cit": return "application/x-cit";
			case "class": return "java/*";
			case "cml": return "text/xml";
			case "cmp": return "application/x-cmp";
			case "cmx": return "application/x-cmx";
			case "cot": return "application/x-cot";
			case "crl": return "application/pkix-crl";
			case "crt": return "application/x-x509-ca-cert";
			case "csi": return "application/x-csi";
			case "cut": return "application/x-cut";
			case "dbf": return "application/x-dbf";
			case "dbm": return "application/x-dbm";
			case "dbx": return "application/x-dbx";
			case "dcd": return "text/xml";
			case "dcx": return "application/x-dcx";
			case "der": return "application/x-x509-ca-cert";
			case "dgn": return "application/x-dgn";
			case "dib": return "application/x-dib";
			case "dot": return "application/msword";
			case "drw": return "application/x-drw";
			case "dtd": return "text/xml";
			case "dwf": return "application/x-dwf";
			case "dwg": return "application/x-dwg";
			case "dxb": return "application/x-dxb";
			case "dxf": return "application/x-dxf";
			case "edn": return "application/vnd.adobe.edn";
			case "emf": return "application/x-emf";
			case "eml": return "message/rfc822";
			case "ent": return "text/xml";
			case "epi": return "application/x-epi";
			case "eps": return "application/x-ps";
			case "etd": return "application/x-ebx";
			case "fax": return "image/fax";
			case "fdf": return "application/vnd.fdf";
			case "fif": return "application/fractals";
			case "fo": return "text/xml";
			case "frm": return "application/x-frm";
			case "g4": return "application/x-g4";
			case "gbr": return "application/x-gbr";
			case "gcd": return "application/x-gcd";
			case "gl2": return "application/x-gl2";
			case "gp4": return "application/x-gp4";
			case "hgl": return "application/x-hgl";
			case "hmr": return "application/x-hmr";
			case "hpg": return "application/x-hpgl";
			case "hpl": return "application/x-hpl";
			case "hqx": return "application/mac-binhex40";
			case "hrf": return "application/x-hrf";
			case "hta": return "application/hta";
			case "htt": return "text/webviewhtml";
			case "htx": return "text/html";
			case "icb": return "application/x-icb";
			case "ico": return "application/x-ico";
			case "iff": return "application/x-iff";
			case "ig4": return "application/x-g4";
			case "igs": return "application/x-igs";
			case "iii": return "application/x-iphone";
			case "img": return "application/x-img";
			case "ins": return "application/x-internet-signup";
			case "isp": return "application/x-internet-signup";
			case "IVF": return "video/x-ivf";
			case "java": return "java/*";
			case "jfif": return "image/jpeg";
			case "jpe": return "application/x-jpe";
			case "la1": return "audio/x-liquid-file";
			case "lar": return "application/x-laplayer-reg";
			case "latex": return "application/x-latex";
			case "lavs": return "audio/x-liquid-secure";
			case "lbm": return "application/x-lbm";
			case "lmsff": return "audio/x-la-lms";
			case "ls": return "application/x-javascript";
			case "ltr": return "application/x-ltr";
			case "m1v": return "video/x-mpeg";
			case "m2v": return "video/x-mpeg";
			case "m3u": return "audio/mpegurl";
			case "m4e": return "video/mpeg4";
			case "mac": return "application/x-mac";
			case "man": return "application/x-troff-man";
			case "math": return "text/xml";
			case "mfp": return "application/x-shockwave-flash";
			case "mht": return "message/rfc822";
			case "mhtml": return "message/rfc822";
			case "mi": return "application/x-mi";
			case "mid": return "audio/mid";
			case "midi": return "audio/mid";
			case "mil": return "application/x-mil";
			case "mml": return "text/xml";
			case "mnd": return "audio/x-musicnet-download";
			case "mns": return "audio/x-musicnet-stream";
			case "mocha": return "application/x-javascript";
			case "movie": return "video/x-sgi-movie";
			case "mpw": return "application/vnd.ms-project";
			case "mpx": return "application/vnd.ms-project";
			case "mtx": return "text/xml";
			case "mxp": return "application/x-mmxp";
			case "net": return "image/pnetvue";
			case "nrf": return "application/x-nrf";
			case "nws": return "message/rfc822";
			case "odc": return "text/x-ms-odc";
			case "out": return "application/x-out";
			case "p10": return "application/pkcs10";
			case "p12": return "application/x-pkcs12";
			case "p7b": return "application/x-pkcs7-certificates";
			case "p7c": return "application/pkcs7-mime";
			case "p7m": return "application/pkcs7-mime";
			case "p7r": return "application/x-pkcs7-certreqresp";
			case "p7s": return "application/pkcs7-signature";
			case "pc5": return "application/x-pc5";
			case "pci": return "application/x-pci";
			case "pcl": return "application/x-pcl";
			case "pcx": return "application/x-pcx";
			case "pdf": return "application/pdf";
			case "pdx": return "application/vnd.adobe.pdx";
			case "pfx": return "application/x-pkcs12";
			case "pgl": return "application/x-pgl";
			case "pic": return "application/x-pic";
			case "pko": return "application/vnd.ms-pki.pko";
			case "pl": return "application/x-perl";
			case "plg": return "text/html";
			case "pls": return "audio/scpls";
			case "plt": return "application/x-plt";
			case "pot": return "application/vnd.ms-powerpoint";
			case "ppa": return "application/vnd.ms-powerpoint";
			case "ppm": return "application/x-ppm";
			case "pps": return "application/vnd.ms-powerpoint";
			case "pr": return "application/x-pr";
			case "prf": return "application/pics-rules";
			case "prn": return "application/x-prn";
			case "prt": return "application/x-prt";
			case "ps": return "application/x-ps";
			case "ptn": return "application/x-ptn";
			case "pwz": return "application/vnd.ms-powerpoint";
			case "r3t": return "text/vnd.rn-realtext3d";
			case "ras": return "application/x-ras";
			case "rat": return "application/rat-file";
			case "rdf": return "text/xml";
			case "rec": return "application/vnd.rn-recording";
			case "red": return "application/x-red";
			case "rgb": return "application/x-rgb";
			case "rjs": return "application/vnd.rn-realsystem-rjs";
			case "rjt": return "application/vnd.rn-realsystem-rjt";
			case "rlc": return "application/x-rlc";
			case "rle": return "application/x-rle";
			case "rmf": return "application/vnd.adobe.rmf";
			case "rmi": return "audio/mid";
			case "rmj": return "application/vnd.rn-realsystem-rmj";
			case "rmm": return "audio/x-pn-realaudio";
			case "rmp": return "application/vnd.rn-rn_music_package";
			case "rms": return "application/vnd.rn-realmedia-secure";
			case "rmx": return "application/vnd.rn-realsystem-rmx";
			case "rnx": return "application/vnd.rn-realplayer";
			case "rp": return "image/vnd.rn-realpix";
			case "rpm": return "audio/x-pn-realaudio-plugin";
			case "rsml": return "application/vnd.rn-rsml";
			case "rt": return "text/vnd.rn-realtext";
			case "rtf": return "application/msword";
			case "rv": return "video/vnd.rn-realvideo";
			case "sam": return "application/x-sam";
			case "sat": return "application/x-sat";
			case "sdp": return "application/sdp";
			case "sdw": return "application/x-sdw";
			case "sit": return "application/x-stuffit";
			case "slb": return "application/x-slb";
			case "sld": return "application/x-sld";
			case "slk": return "drawing/x-slk";
			case "smi": return "application/smil";
			case "smil": return "application/smil";
			case "smk": return "application/x-smk";
			case "snd": return "audio/basic";
			case "sol": return "text/plain";
			case "sor": return "text/plain";
			case "spc": return "application/x-pkcs7-certificates";
			case "spl": return "application/futuresplash";
			case "spp": return "text/xml";
			case "ssm": return "application/streamingmedia";
			case "sst": return "application/vnd.ms-pki.certstore";
			case "stl": return "application/vnd.ms-pki.stl";
			case "stm": return "text/html";
			case "sty": return "application/x-sty";
			case "svg": return "text/xml";
			case "tdf": return "application/x-tdf";
			case "tg4": return "application/x-tg4";
			case "tga": return "application/x-tga";
			case "tld": return "text/xml";
			case "top": return "drawing/x-top";
			case "tsd": return "text/xml";
			case "txt": return "text/plain";
			case "uin": return "application/x-icq";
			case "uls": return "text/iuls";
			case "vcf": return "text/x-vcard";
			case "vda": return "application/x-vda";
			case "vdx": return "application/vnd.visio";
			case "vml": return "text/xml";
			case "vpg": return "application/x-vpeg005";
			case "vsd": return "application/vnd.visio";
			case "vss": return "application/vnd.visio";
			case "vst": return "application/vnd.visio";
			case "vsw": return "application/vnd.visio";
			case "vsx": return "application/vnd.visio";
			case "vtx": return "application/vnd.visio";
			case "vxml": return "text/xml";
			case "wax": return "audio/x-ms-wax";
			case "wb1": return "application/x-wb1";
			case "wb2": return "application/x-wb2";
			case "wb3": return "application/x-wb3";
			case "wbmp": return "image/vnd.wap.wbmp";
			case "wiz": return "application/msword";
			case "wk3": return "application/x-wk3";
			case "wk4": return "application/x-wk4";
			case "wkq": return "application/x-wkq";
			case "wks": return "application/x-wks";
			case "wm": return "video/x-ms-wm";
			case "wmd": return "application/x-ms-wmd";
			case "wmf": return "application/x-wmf";
			case "wmx": return "video/x-ms-wmx";
			case "wmz": return "application/x-ms-wmz";
			case "wp6": return "application/x-wp6";
			case "wpd": return "application/x-wpd";
			case "wpg": return "application/x-wpg";
			case "wpl": return "application/vnd.ms-wpl";
			case "wq1": return "application/x-wq1";
			case "wr1": return "application/x-wr1";
			case "wri": return "application/x-wri";
			case "wrk": return "application/x-wrk";
			case "ws": return "application/x-ws";
			case "ws2": return "application/x-ws";
			case "wsc": return "text/scriptlet";
			case "wvx": return "video/x-ms-wvx";
			case "xdp": return "application/vnd.adobe.xdp";
			case "xdr": return "text/xml";
			case "xfd": return "application/vnd.adobe.xfd";
			case "xfdf": return "application/vnd.adobe.xfdf";
			case "xq": return "text/xml";
			case "xql": return "text/xml";
			case "xquery": return "text/xml";
			case "xwd": return "application/x-xwd";
			case "x_b": return "application/x-x_b";
			case "x_t": return "application/x-x_t";
		}
		return "application/octet-stream";
	}

至此,就可以完成文件的上傳與回顯:
在這裏插入圖片描述

踩過的坑:

1、前後端分離項目會出現端口號問題,請求不到後臺。如前端端口是8000,而後端項目是8080,此時,要在ueditor.config.js文件中的UEDITOR_HOME_URL變量和serverUrl均加上項目的前綴。如:
UEDITOR_HOME_URL: http://localhost:8080/project/static/ueditor1_4_3_3/;
serverUrl: http://localhost:8080/project/api/ueditor/exec

2、controller中的exec接口一定要按照文中的設置contentType,前端讀取config.json配置文件時,後端需要返回一個js文件;而上傳文件時,後端需要返回text。

3、回顯圖片時,一定要根據文件類型設置對應的ContentType,否則顯示圖片時,是下載了該圖片至本地,而不是回顯在界面上。

4、ueditor源碼包一定要去官網下載,剛開始樓主在公司倉庫裏下載的jar包,包名看起來像官方源碼包,其實裏面代碼都是坑。。。才知道會有人傳假包害人。。。切記切記。。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章