【CKeditor】使用SpringMVC处理CKeditor上传图片

0、了解CKeditor的相关文件以及引入js

    引入ckeditor的js

<script type="text/javascript" src="<c:url value="/resources/js/ckeditor/ckeditor.js" />"></script>

1、开启CKeditor上传图片功能

官方说明

简明的说,就是只需要在创建CKeditor时,添加以下两个配置:

在用CKEDITOR.replace()中配置

filebrowserBrowseUrl: '自定义的请求',
filebrowserUploadUrl: '自定义的请求'
CKEDITOR.replace('editor',{
    filebrowserBrowseUrl: '/browser/browse.php',
    filebrowserUploadUrl: '/uploader/upload.php'
});

或,在config.js添加如下配置

config.filebrowserBrowseUrl='自定义的请求', config.filebrowserUploadUrl='自定义的请求' 

2、编写自定义的请求

@RequestMapping(value="/ckeditor/uploadFile")
	public void uploadFile(@RequestParam("upload") MultipartFile multipartFile,HttpServletRequest request,HttpServletResponse response){
		response.setContentType("text/html;charset=UTF-8");
//		response.setHeader("X-Frame-Options", "SAMEORIGIN");
		String CKEditorFuncNum = request.getParameter("CKEditorFuncNum");
		PrintWriter out;
		String s = "<script type=\"text/javascript\">window.parent.CKEDITOR.tools.callFunction("+CKEditorFuncNum+", '"+multipartFile.getOriginalFilename()+"');</script>";
		try {
			out = response.getWriter();
			out.print(s);
			out.flush();
		} catch (IOException e) {
			e.printStackTrace();
		}
		
		
	}




问题及解决方案:

1、解决ckeditor上传,返回时显示js代码不显示图片的问题

问题解决:

未配置response的ContentType

response.setContentType("text/html;charset=UTF-8");

解决ckeditor上传,返回时显示js代码不显示图片的问题  

2、跨域问题

chrome console log:

Refused to display 'http://localhost:8080/webcnmain/ifacompany/article/uploadArticleImageForCkeditor?CKEditor=articleContentZH&CKEditorFuncNum=1&langCode=zh-cn' in a frame because it set 'X-Frame-Options' to 'DENY'.

解决方法

response.setHeader("X-Frame-Options", "SAMEORIGIN");

3.spring 上传文件未配置相关的视图解析器

java.lang.IllegalArgumentException: Expected MultipartHttpServletRequest: is a MultipartResolver configured?


转载于:https://my.oschina.net/jast90/blog/295636

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值