一、在线编辑器KindEditor下载

下载 KindEditor 最新版本,下载之后打开 examples/index.html 就可以看到演示。

下载页面:

二、部署编辑器

   (1) 解压 kindeditor-x.x.x.zip 文件,重命名kindeditor,将所有文件上传到您的网站程序目录里,

    例如:/localhost/shop/kindeditor/(shop为网站名),

Note

您可以根据需求删除以下目录后上传到服务器。

  • asp - ASP程序(删除)

  • asp.net - ASP.NET程序(删除)

  • php - PHP程序(删除)

  • jsp - JSP程序(保留)

  • examples - 演示文件(保留)

(2)将jsp文件夹下/lib目录下3个jar文件复制到Tomcat/lib目录下或shop/WEB-INF/lib目录下

    commons-fileupload-1.2.1.jar

    commons-io-1.4.jar

    json_simple-1.1.jar

   如果使用MyEclipse需要添加扩展包

(3)将/kendeditor/jsp文件夹下upload_json.jsp,file_manager_json.jsp剪切到/kendeditor/目录下

(4)将/kendeditor目录下attached放到网站根目录 (shop下)

三、在线编辑器使用(jsp文件夹下demo.jsp文件,由于相关文件位置发生了变化,相应路径发生变化)

将jsp文件夹下demo.jsp文件另存到shop/admin/目录下

shop/admin/demo.jsp

shop/kindeditor/相关在线编辑器文件

demo.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%
request.setCharacterEncoding("UTF-8");
String htmlData = request.getParameter("content1") != null ? request.getParameter("content1") : "";
%>
<!doctype html>
<html>
<head>
    <meta charset="utf-8" />
    <title>KindEditor JSP</title>
  
 <link rel="stylesheet" href="../kindeditor/themes/default/default.css" />
    <link rel="stylesheet" href="../kindeditor/plugins/code/prettify.css" />
    <script charset="utf-8" src="../kindeditor/kindeditor.js"></script>
    <script charset="utf-8" src="../kindeditor/lang/zh_CN.js"></script>
    <script charset="utf-8" src="../kindeditor/plugins/code/prettify.js"></script>
    <script>
        KindEditor.ready(function(K) {
            var editor1 = K.create('textarea[name="content1"]', {
                cssPath : '../
kindeditor/plugins/code/prettify.css',
                uploadJson : '../
kindeditor/upload_json.jsp',
                fileManagerJson : '../
kindeditor/file_manager_json.jsp',
                allowFileManager : true,
                afterCreate : function() {
                    var self = this;
                    K.ctrl(document, 13, function() {
                        self.sync();
                        document.forms['example'].submit();
                    });
                    K.ctrl(self.edit.doc, 13, function() {
                        self.sync();
                        document.forms['example'].submit();
                    });
                }
            });
            prettyPrint();
        });
    </script>
</head>
<body>
    <%=htmlData%>
    <form name="example" method="post" action="demo.jsp">
        <textarea name="content1" cols="100" rows="8" style="width:700px;height:200px;visibility:hidden;"><%=htmlspecialchars(htmlData)%></textarea>
        <br />
        <input type="submit" name="button" value="提交内容" /> (提交快捷键: Ctrl + Enter)
    </form>
</body>
</html>
<%!
private String htmlspecialchars(String str) {
    str = str.replaceAll("&", "&amp;");
    str = str.replaceAll("<", "&lt;");
    str = str.replaceAll(">", "&gt;");
    str = str.replaceAll("\"", "&quot;");
    return str;
}

%>

四、实现商品描述功能

添加商品页面中的“商品描述”应用“在线编辑器”完成

将demojsp内容复制到good_add.jsp文件中相应位置

将content1 更改为content,由于位置很多,采用替换方式

将表单名example替换为form(script也包含)

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>

<%@ page import="mybean.*,java.util.*"%>
<%
request.setCharacterEncoding("UTF-8");
String htmlData = request.getParameter("content") != null ? request.getParameter("content") : "";
%>
<!doctype html>
<html>
<head>
    <meta charset="utf-8" />
    <title>KindEditor JSP</title>
    <link rel="stylesheet" href="../kindeditor/themes/default/default.css" />
    <link rel="stylesheet" href="../kindeditor/plugins/code/prettify.css" />
    <script charset="utf-8" src="../kindeditor/kindeditor.js"></script>
    <script charset="utf-8" src="../kindeditor/lang/zh_CN.js"></script>
    <script charset="utf-8" src="../kindeditor/plugins/code/prettify.js"></script>
    <script>
        KindEditor.ready(function(K) {
            var editor1 = K.create('textarea[name="content"]', {
                cssPath : '../kindeditor/plugins/code/prettify.css',
                uploadJson : '../kindeditor/upload_json.jsp',
                fileManagerJson : '../kindeditor/file_manager_json.jsp',
                allowFileManager : true,
                afterCreate : function() {
                    var self = this;
                    K.ctrl(document, 13, function() {
                        self.sync();
                        document.forms['form1'].submit();
                    });
                    K.ctrl(self.edit.doc, 13, function() {
                        self.sync();
                        document.forms['form1'].submit();
                    });
                }
            });
            prettyPrint();
        });
    </script>
     
</head>
<body>
    <%=htmlData%>
    
     <form id="form1" name="form1" method="post" action="good_doAdd.jsp">
  <table  border="1" cellspacing="0">
    <tr>
      <td width="100">商品名称</td>
      <td><input type="text" name="name" id="name" /></td>
    </tr>
     <tr>
      <td>商品图片</td>
      <td><input type="text" size=40 name="picture" id="picture" value="" /> <input type="button" id="p_w_picpath1" value="浏览" /></td>
    </tr>
    <tr>
      <td>商品描述</td>
      <td><textarea name="content" cols="100" rows="8" style="width:700px;height:200px;visibility:hidden;"><%=htmlspecialchars(htmlData)%></textarea></td>
    </tr>
    <tr>
      <td>商品价格</td>
      <td><input type="text" name="price" id="price" /></td>
    </tr>
    <tr>
      <td>商品数量</td>
      <td><input type="text" name="num" id="num" /></td>
    </tr>
    <tr>
      <td>商品类型</td>
      <!--
      <td><select name="type" id="type">
         <option value="">--商品类型--</option>
        <option value="1">电脑</option>
        <option value="2">手机</option>
        <option value="3">电动车</option>
        <option value="4">洗衣机</option>
        <option value="5">MP3</option>
      </select></td>
       -->
         <td>
             <select name="type" id="type">
             <option value="">--商品类型--</option>
             <%
             TypeGoodsDAO tdao=new TypeGoodsDAO();
             LinkedList<TypeGoods> ts=tdao.list();
             for(TypeGoods t:ts){
              %>
    
                    <option value="<%=t.getTypeId()%>"><%=t.getTypeName()%></option>
         
             <%} %>
          </select></td>
    </tr>
    <tr>
      <td></td>
      <td><input type="submit" value="提交"/></td>
    </tr>
  </table>
</form>
    
    
    
    
</body>
</html>
<%!
private String htmlspecialchars(String str) {
    str = str.replaceAll("&", "&amp;");
    str = str.replaceAll("<", "&lt;");
    str = str.replaceAll(">", "&gt;");
    str = str.replaceAll("\"", "&quot;");
    return str;
}
%>

五、实现商品图片上传

1、good_add.jsp相应位置添加代码

   <tr>

      <td>商品图片</td>
      <td><input type="text" size=40 name="picture" id="picture" value="" /> <input type="button" id="p_w_picpath1" value="浏览" /></td>
    </tr>

2、good_add.jsp添加脚本(复制example/p_w_picpath-dialog.html部分内容)

<script type="text/javascript">

    KindEditor.ready(function(K) {
                var editor = K.editor({
                uploadJson : '../kindeditor/upload_json.jsp',
                fileManagerJson : '../kindeditor/file_manager_json.jsp',
                    allowFileManager : true
                });
                K('#p_w_picpath1').click(function() {
                    editor.loadPlugin('p_w_picpath', function() {
                        editor.plugin.p_w_picpathDialog({
                            p_w_picpathUrl : K('#picture').val(),
                            clickFn : function(url, title, width, height, border, align) {
                                K('#picture').val(url);
                                editor.hideDialog();
                            }
                        });
                    });
                });
        });
    </script>

3、添加以下语句实现获得上传文件

  uploadJson : '../kindeditor/upload_json.jsp',

  fileManagerJson : '../kindeditor/file_manager_json.jsp',