`

让CKEditor支持JSP文件上传

阅读更多

很早以前就想把CKEditor在JSP下的图片上传及浏览服务器图片的方法写下来了,不过因为教学项目中要用到,担心HEM直接套用,自己不去调查(我可是用心良苦啊),不能很好的锻炼,一直没写出来,今天项目开始测试了,他们的功能也都基本可以结束了,我也可以发我的帖了。

写这个的起因是在网上一仁兄的帖子,抱怨说CKEditor不支持JSP了,感叹了许多,说支持ASP、PHP,就是不支持JSP,于是俺也在网上找了找JSP方面的资料,看来确实不支持了,不过人家也是有道理的,毕竟JSP上传的图片,不能简单的用个JSP就随便搞搞就O了。

关于CKEditor在JSP下上传图片的方法,网上有很多,大都是写了一大堆JS代码然后自己注册一个事件,写的太多,我没怎么看懂,不过有一位大侠写的让我看到了简单写法的曙光(不过遗憾的是,时间太长了,不知道大侠的URL了)。

言归正传,对于上传CKEditor已经做好了,我们只要准备个功能,接收CKEditor提交过来的文件就可以了,所以呢实现的思路是:

 

  1. 准备一下JSP上传文件的JAR包:commons-fileupload.jar和commons-io.jar
  2. 编写一个JSP用于接收上传的文件(这里除上传图片功能外,需调用一个核心JS语句)
  3. 编写一个JSP用于浏览文件(这里除上传图片功能外,需调用一个核心JS语句)
  4. 修改CKEditor的config.js,将上传文件和浏览文件的JSP配置进去

说明一下,之所以采用JSP没有使用Servlet,那是因为JSP简单啊,这样可以降低CKEditor对项目的侵入性啊。下面看代码啦:

用于接收上传的文件的JSP:

<%@page import="java.io.File"%>
<%@page import="java.util.UUID"%>
<%@page import="org.apache.commons.fileupload.FileItem"%>
<%@page import="java.util.List"%>
<%@page import="org.apache.commons.fileupload.disk.DiskFileItemFactory"%>
<%@page import="org.apache.commons.fileupload.FileItemFactory"%>
<%@page import="org.apache.commons.fileupload.servlet.ServletFileUpload"%>
<%@ page language="java" contentType="text/html; charset=GB18030" pageEncoding="GB18030"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<title>JSP上传文件</title>
</head>
<body>
<%
String path = request.getContextPath() + "/";
if(ServletFileUpload.isMultipartContent(request)){
	String type = "";
	if(request.getParameter("type") != null)//获取文件分类
		type = request.getParameter("type").toLowerCase() + "/";
	String callback = request.getParameter("CKEditorFuncNum");//获取回调JS的函数Num
	FileItemFactory factory = new DiskFileItemFactory();
	ServletFileUpload servletFileUpload = new ServletFileUpload(factory);
	servletFileUpload.setHeaderEncoding("UTF-8");//解决文件名乱码的问题
	List<FileItem> fileItemsList = servletFileUpload.parseRequest(request);
	for (FileItem item : fileItemsList) {
		if (!item.isFormField()) {
			String fileName = item.getName();
			fileName = "file" + System.currentTimeMillis() + fileName.substring(fileName.lastIndexOf("."));
			//定义文件路径,根据你的文件夹结构,可能需要做修改
			String clientPath = "ckeditor/uploader/upload/" + type + fileName;

			//保存文件到服务器上
			File file = new File(request.getSession().getServletContext().getRealPath(clientPath));
			if (!file.getParentFile().exists()) {
				file.getParentFile().mkdirs();
			}
			item.write(file);

			//打印一段JS,调用parent页面的CKEditor的函数,传递函数编号和上传后文件的路径;这句很重要,成败在此一句
			out.println("<script type='text/javascript'>window.parent.CKEDITOR.tools.callFunction("+callback+",'"+path+clientPath+"')</script>");
			break;
		}
	}
}
 %>
</body>
</html>

用于浏览文件的JSP:

<%@page import="java.io.File"%>
<%@ page language="java" contentType="text/html; charset=GB18030"
    pageEncoding="GB18030"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<title>图片浏览</title>
<script type="text/javascript">
//这段函数是重点,不然不能和CKEditor互动了
function funCallback(funcNum,fileUrl){
	var parentWindow = ( window.parent == window ) ? window.opener : window.parent;
	parentWindow.CKEDITOR.tools.callFunction(funcNum, fileUrl);
	window.close();
}
</script>
</head>
<body>
<%
	String path = request.getContextPath() + "/";
	String type = "";
	if(request.getParameter("type") != null)//获取文件分类
		type = request.getParameter("type").toLowerCase() + "/";
	String clientPath = "ckeditor/uploader/upload/" + type;
	File root = new File(request.getSession().getServletContext().getRealPath(clientPath));
	if(!root.exists()){
		root.mkdirs();
	}
	String callback = request.getParameter("CKEditorFuncNum");
	File[] files = root.listFiles();
	if(files.length > 0){
		for(File file:files ) {
			String src = path + clientPath + file.getName();
			out.println("<img width='110px' height='70px' src='" + src + "' alt='" + file.getName() + "' onclick=\"funCallback("+callback+",'"+ src +"')\">");
		}
	}else{
		out.println("<h3>未检测到资源。</h3>");
	}
 %>
</body>
</html>

修改后的CKEditor的config.js: 

CKEDITOR.editorConfig = function( config )
{
	config.language = 'zh-cn';
	config.filebrowserBrowseUrl = 'ckeditor/uploader/browse.jsp';
	config.filebrowserImageBrowseUrl = 'ckeditor/uploader/browse.jsp?type=Images';
	config.filebrowserFlashBrowseUrl = 'ckeditor/uploader/browse.jsp?type=Flashs';
	config.filebrowserUploadUrl = 'ckeditor/uploader/upload.jsp';
	config.filebrowserImageUploadUrl = 'ckeditor/uploader/upload.jsp?type=Images';
	config.filebrowserFlashUploadUrl = 'ckeditor/uploader/upload.jsp?type=Flashs';
	config.filebrowserWindowWidth = '640';
	config.filebrowserWindowHeight = '480';
}

OK,修改完毕。简单吧,其实上传和浏览文件很简单(上面只是一个演示,代码仅供参考),要点是要调用一下CKEDITOR.tools.callFunction方法。

附件打包了一个可运行的Eclipse工程,供需要的朋友参考。

---------------------------------------------------------------------------------------

图片预览:

文件夹结构截图


上传效果截图:



 
 

  • 大小: 17 KB
  • 大小: 31 KB
  • 大小: 19.2 KB
  • 大小: 44.9 KB
  • 大小: 61.2 KB
18
1
分享到:
评论
27 楼 qzshiyongjie 2014-05-17  
真是帮了我大忙了。我用的是spring mvc 尝试了各种方法,配置了各种.do,都没解决。最后到想到为什么不能用jsp呢,这不,一搜就到您着了。太感谢了,3Q so more
26 楼 minrui 2014-04-15  
hu401348817 写道
各位大佬,请问能否配置ckeditor的config.js 限制图片的宽度和高度,超过尺寸,自动设置为某一个值

解决了吗?
25 楼 xiaoxiashashen 2014-04-09  
[url][/url][size=xx-small][img] [/img][img][/img][/size]
24 楼 hu401348817 2014-03-28  
各位大佬,请问能否配置ckeditor的config.js 限制图片的宽度和高度,超过尺寸,自动设置为某一个值
23 楼 bboymoney 2014-01-07  
hao !
22 楼 suyonghe678 2013-01-21  
原本引入ckfinder,弄了一个星期,救了我一命
21 楼 搞基园长 2012-06-18  
楼主可能放是没有见过JSP WEBSHELL 所以敢不判断上传格式
20 楼 guomi2004 2012-05-19  
果然好方法,感谢
19 楼 yinli1108 2012-05-08  
LZ您好,谢谢你的代码,但是我遇到一点小问题,当上传的不是图片的话,显示在编辑器的内容是个红色的小马叉,就如同我们点击网页 图片未加载成功的样子,必须手动del才可以,另外有什么方式让我上传的HTML 能够在编辑器里面显示呢?谢谢,盼回复!
18 楼 Mojarra 2012-03-29  
不错,很详细,可以研究研究,收藏一下
17 楼 coolzhi 2011-12-12  
还有一种做法是可以将fckeditor的文件上传管理器移植过来就可以用了,详细情况可以看文章《ckeditor用fckeditor的文件管理器实现图片上传

如果嫌弃fckeditor文件管理器不好看的话,还可以使用很多开源的可集成到ckeditor的文件管理器。。包括kfm、filemanager等。
16 楼 passlicense 2011-09-05  
问题1:但是不能选择其他路径下的图片,不灵活
问题2:在ie下点击上传图片的时候,窗口都没跳出来
请问楼主是怎么回事啊??
15 楼 passlicense 2011-09-05  
挺优雅的方法啊。网络上其他的方法太复杂了!!
14 楼 夕雨下 2011-06-15  
LZ你太给力了, 谢谢啊
13 楼 zywang 2011-04-20  
Ayin2767 写道
用了,太强了,谢谢!楼主

客气,略尽绵薄之力
12 楼 Ayin2767 2011-04-20  
用了,太强了,谢谢!楼主
11 楼 zywang 2011-03-23  
LD_21 写道
好像使用在struts2中就不行了啊,除非把web.xml中filter-mapping的url-pattern从 /* 改为 *.action ,请问楼主有没更好的解决方式??

这需要对上面的代码进行修改,将我写在JSP中的Java代码迁移到Struts的Action中,同时将CKEditor的config.js中的URL指向该Action;当然上传文件的代码也可以按照Struts的方式进行上传。总的来说,是JSP还是Action不是重点,重点是你要能执行CKEDITOR.tools.callFunction这段JS代码
10 楼 LD_21 2011-03-22  
好像使用在struts2中就不行了啊,除非把web.xml中filter-mapping的url-pattern从 /* 改为 *.action ,请问楼主有没更好的解决方式??
9 楼 yhanliang 2010-12-29  
8 楼 supben 2010-12-12  
zywang 写道
supben 写道
赞一个!我记得我原来改的,又是加servlet又是改配置,设计到接近10个地方,非常的复杂,楼主的这个版本侵入性很低。以后ckeditor的版本升级也可以随时跟进。

不过我有个问题,IE8,一直报ckeditor.js拒绝访问的错, 火狐没问题!
而且我上ckeditor官网,用IE,所有的demo都看不了,和我本地的效果一样!
为什么?与js文件编码是utf-8+ (bom) 有关系?
我最纳闷的是,难道作者他们不知道IE8不支持,这么大的问题!
难道故意的,支持IE8的要付费?

盼楼主回音

我电脑上用的就是IE8,没有出现你说的情况啊,是不是你的IE坏了啊

恩,我另外一台机器没事。。。。

相关推荐

    CKEditor 应用 源码 JSP

    在JSP(JavaServer Pages)环境中集成CKEditor,可以让用户在服务器端进行更加直观和便捷的内容创作。本资料包含了CKEditor在JSP中的应用实例,以及相关的配置和使用说明。 首先,我们来看如何在JSP中引入CKEditor...

    ckeditor上传图片,上传文件

    在这个例子中,`testCkeditorUploadImg.jsp`可能包含了一个预配置好的CKEditor实例,以及相关的JavaScript代码,用于配置CKEditor的图片和文件上传功能。这部分代码可能涉及到CKEditor的配置对象,如`config....

    jsp中使用ckeditor

    2. `ckeditor-java-core-3.5.3.jar`:这是CKEditor Java库的核心文件,包含了CKEditor与Java交互的代码,我们需要将其添加到项目的类路径中,以便在JSP页面上使用CKEditor。 3. `ckeditor-java-core-3.5.3-sources....

    ckeditor jsp 上传图片例子 免费下载

    3. **处理文件上传**:在JSP中,可以使用`&lt;form&gt;`标签来接收文件,通过`request.getParameter("CKEditorFuncNum")`获取CKEditor回调函数的编号,以便在上传成功后通知编辑器。使用`Part`接口(Java Servlet 3.0及...

    ckEditor在jsp中的使用

    ckEditor是一款非常流行的富文本编辑器,它能够提供强大的文本编辑功能,包括图片上传、格式化文本等,广泛应用于各类网站和应用中。本文将详细介绍如何在JSP页面中集成ckEditor,并通过示例代码来展示具体的实现...

    CKeditor v3.2.1 JSP增强版 - 【带Servlet上传功能+完整源码+实例】.rar

    总的来说,这个压缩包提供了一整套CKeditor v3.2.1 JSP增强版的解决方案,对于那些需要在Java Web环境中实现富文本编辑和文件上传功能的开发者来说,是一个非常有价值的资源。通过研究源码和实例,开发者可以深入...

    jspupload.rar_ckeditor java

    总之,"jspupload.rar_ckeditor java"是一个关于如何在Java Web项目中利用CKEditor进行JSP文件上传的资源,它可能包含了一个完整的解决方案或者详细教程,对于使用CKEditor进行Web开发的程序员来说,是极具价值的...

    JSP使用ckeditor和ckfinder实现富文本及文件上传

    在这个场景中,"JSP使用ckeditor和ckfinder实现富文本及文件上传"是一个常见的需求,尤其是在构建内容管理系统或者论坛等需要用户编辑和上传内容的Web应用中。 ckeditor是一款流行的开源JavaScript富文本编辑器,它...

    ckeditor 带上传例子 for java jsp

    总结来说,这个"ckeditor带上传例子 for java jsp"是一个展示如何在Java Web环境中集成CKEditor并实现文件上传功能的实例。通过部署提供的WAR文件到Tomcat服务器,你可以学习和实践如何处理CKEditor的上传请求,以及...

    ckeditor配置上传视频

    最后配置视频上传路径的URL路径,也就是POST上传文件的地址:config.filebrowserFlvPlayerUploadUrl = '/ckeditor/upload_json.ashx?dir=media',注意一定要是filebrowserFlvPlayerUploadUrl,这里要对应flvPlayer...

    ckeditor+struts2上传图片

    4. **返回响应**:完成文件上传后,Action需要返回一个响应,告知CKEditor图片是否成功上传。这个响应可以是JSON格式,包含图片的URL,这样CKEditor就能在编辑器中显示上传的图片。 5. **配置Struts2**:在Struts2...

    Ckeditor + ckfinder整合for JAVA(支持文件上传)

    通过以上步骤,你就可以在Java Web项目中成功整合Ckeditor和ckFinder,提供一个支持文件上传的富文本编辑器。在实际开发中,你可能还需要根据项目需求进行一些定制化工作,例如调整编辑器样式、增加额外的插件等。...

    CKEditor+CKFinder的jsp实例

    CKFinder则是一个与CKEditor配套的文件管理器,用于上传、浏览和管理服务器上的文件。通过CKFinder,用户可以直接在编辑器中插入图片、文档或其他媒体文件,而无需离开编辑环境。CKFinder支持多种文件类型,并具有...

    CKEDITOR 编辑器本地上传图片(好)

    例如,限制上传文件的类型和大小,防止恶意文件上传;对上传的图片进行缩放和优化,减少服务器存储空间和加载时间;以及使用CDN服务,提高图片加载速度。 总结,CKEDITOR编辑器的本地图片上传功能结合服务器端处理...

    关于jsp中ckeditor+ckfinder

    ### 关于JSP中ckeditor...通过本文详细介绍的步骤,可以有效地将ckeditor与ckfinder整合到JSP项目中,实现文件上传、图片插入等功能。这种方法不仅提高了用户体验,还简化了开发过程中的复杂度,是非常实用的技术组合。

    CKeditor的图片上传浏览服务端组件-Java版本

    kcFinder是一个开源的文件管理器,它支持多语言,可以轻松集成到CKeditor中,提供文件和目录的浏览、删除、重命名等功能。 3. **路径配置**:为了使CKeditor能够正确地显示上传的图片,服务端组件需要配置正确的URL...

    ckeditor上传图片

    `testCkeditorUploadImg.jsp`是一个JSP(JavaServer Pages)文件,通常用于测试或者演示CKEditor的图片上传功能。在这个文件中,可以看到HTML和JavaScript代码,它们创建了一个CKEditor实例,并配置了图片上传的相关...

    jsp文件上传示例+在线编辑器

    本示例“jsp文件上传示例+在线编辑器”着重展示了如何在Java服务器页面(JSP)中实现文件上传,并结合在线编辑器提供一个完整的用户体验。 首先,我们来详细讨论JSP文件上传。JSP(JavaServer Pages)是一种基于...

Global site tag (gtag.js) - Google Analytics