今日整合某项目的博客发表功能,须要用到在线编译器,在网上搜索了一大堆后决定采用ckeditor+ckfinder,可是使用过程当中发现此插件太大,且自定义,权限方面的配置工做过于复杂,加之国内中文帮助文档较少,因此最后仍是弃了ck用了ke。php
废话不说了,进入正题html
一,先去KindEditor下载http://www.kindsoft.net/相应包,若是你项目使用的是jsp记得将jsp/lib下的内容加入到你的项目中,具体怎么操做就不一步一步详解了,直接总结问题。java
二, 整合出现的问题:web
1,KindEditor对象未定义apache
解决方法:json
这个确定是你引入kindeditor.js时,路径有问题或js加载顺序的问题服务器
2,图片上传路径问题app
解决方法:dom
修改此段jsp
//文件保存目录路径(改为本身的路径)
String savePath = pageContext.getServletContext().getRealPath("/") + "blogimage/";
//文件保存目录URL(改为本身的url)
String saveUrl = request.getContextPath() + "/blogimage/";
3,上传本地图片时没有写入权限
缘由:这个是因为webxml中的过滤器
<filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>*.jsp</url-pattern> </filter-mapping>
解决办法:
若是你项目中*.jsp能够改为*.action,那你就只须要重写upload_json.jsp便可;
upload_json.jsp代码重写以下,出处(http://www.kindsoft.net/view.php?bbsid=7&postid=2561&pagenum=3):
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.util.*,java.io.*"%> <%@ page import="java.text.SimpleDateFormat"%> <%@ page import="org.apache.commons.fileupload.*"%> <%@ page import="org.apache.commons.fileupload.disk.*"%> <%@ page import="org.apache.commons.fileupload.servlet.*"%> <%@ page import="com.opensymphony.xwork2.ActionContext"%> <%@ page import="org.apache.struts2.dispatcher.multipart.MultiPartRequestWrapper"%> <%@ page import="org.json.simple.*"%> <% //文件保存目录路径 img_upload是服务器存储上传图片的目录名 String savePath = request.getSession().getServletContext().getRealPath("/")+ "img_upload/"; //文件保存目录URL String saveUrl = request.getContextPath() + "/img_upload/"; //定义容许上传的文件扩展名 String[] fileTypes = new String[] { "gif", "jpg", "jpeg", "png","bmp" }; //容许最大上传文件大小 long maxSize = 1024000; //Struts2 请求 包装过滤器 MultiPartRequestWrapper wrapper = (MultiPartRequestWrapper) request; //得到上传的文件名 String fileName = wrapper.getFileNames("imgFile")[0]; //得到文件过滤器 File file = wrapper.getFiles("imgFile")[0]; //获得上传文件的扩展名 String fileExt = fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase(); //检查扩展名 if (!Arrays.<String> asList(fileTypes).contains(fileExt)) { out.println(getError("上传文件扩展名是不容许的扩展名。")); return; } //检查文件大小 if (file.length() > maxSize) { out.println(getError("上传文件大小超过限制。")); return; } //检查目录 File uploadDir = new File(savePath); if (!uploadDir.isDirectory()) { out.println(getError("上传目录不存在。")); return; } //检查目录写入权限 if (!uploadDir.canWrite()) { out.println(getError("上传目录没有写入权限。")); return; } //重构上传图片的名称 SimpleDateFormat df = new SimpleDateFormat("yyyyMMddHHmmss"); String newImgName = df.format(new Date()) + "_"+ new Random().nextInt(1000) + "." + fileExt; //设置 KE 中的图片文件地址 String newFileName = request.getScheme() + "://"+ request.getServerName() + ":" + request.getServerPort() + saveUrl + newImgName; byte[] buffer = new byte[1024]; //获取文件输出流 FileOutputStream fos = new FileOutputStream(savePath + newImgName); //获取内存中当前文件输入流 InputStream in = new FileInputStream(file); try { int num = 0; while ((num = in.read(buffer)) > 0) { fos.write(buffer, 0, num); } } catch (Exception e) { e.printStackTrace(System.err); } finally { in.close(); fos.close(); } //发送给 KE JSONObject obj = new JSONObject(); obj.put("error", 0); obj.put("url", saveUrl + newImgName); out.println(obj.toJSONString()); %> <%!private String getError(String message) { JSONObject obj = new JSONObject(); obj.put("error", 1); obj.put("message", message); return obj.toJSONString(); } %>
为何须要重写upload_json.jsp,是由于structs2对request进行了包装,致使页面中的file对象为空,因此咱们须要使用到MultiPartRequestWrapper 进行处理,具体过程可查看它的源码及实现过程。
由于我项目中使用到了structs2的标签,因此不加*.jsp的过滤器则会致使项目中的structs2的标签没法正常使用。
所以上面的解决方法不适用于个人项目,项目中惟一的解决方法是将upload_json.jsp重写成servlet或structs2的action,重写过程当中会用到response.getWriter().println(str)
若有错误之处,请各位大侠赐教
可提供ckeditor+ckfinder整合的简单demo,须要可留言
我的博客网站:www.fuzhicode.com
爱泡泡优惠券网站:www.shaobingquan.com,提供淘宝,天猫购物优惠券