springmvc+kindeditor文件上传实例详解

本文实例为大家分享了springmvc+kindeditor文件上传的具体代码,供大家参考,具体内容如下

下载kindeditor

压缩包里面的jar放到tomcat的lib文件夹下,kindeditor文件放工程里,不用的可以删掉

jsp页面

<%@ page language="java" contentType="text/html; charset=UTF-8"
 pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<link rel="stylesheet"
 href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" >
<script src="https://cdn.bootcss.com/jquery/2.1.1/jquery.min.js"></script>
<script
 src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script src="./kindeditor/kindeditor-all-min.js"></script>
<script src="./kindeditor/lang/zh-CN.js"></script>
<script>
 KindEditor
   .ready(function(K) {
    window.editor = K
      .create(
        '#editor_id',
        {
         uploadJson : 'Kindeditor/uploadFile',
         fileManagerJson : 'Kindeditor/fileManager',
         allowImageUpload : true, //多图上传
         allowFileManager : true, //浏览图片空间
         filterMode : false, //HTML特殊代码过滤
         afterBlur : function() {
          this.sync();
         }, //编辑器失去焦点(blur)时执行的回调函数(将编辑器的HTML数据同步到textarea)
         afterUpload : function(url, data, name) { //上传文件后执行的回调函数,必须为3个参数
          if (name == "image"
            || name == "multiimage") { //单个和批量上传图片时
           if (K("#pic").length > 0) { //文本框存在
            document
              .getElementById('piclist').options[document
              .getElementById('piclist').length] = new Option(
              url, url); //下拉列表框增加一条
            document
              .getElementById('piclist').selectedIndex += 1; //选定刚新增的这一条
            K("#indexpicimg")
              .html(
                "<img src='" + url + "' width='150' height='95' />"); //重置图片展示区DIV的HTML内容
            K("#pic").val(url); //重置文本框值
           }
          }
         }
        });
   });
</script>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <form class="form-horizontal" role="form" action="articleAdd" method="post" >
  <div class="form-group">
   <label for="firstname" class="col-sm-2 control-label">标题</label>
   <div class="col-sm-5">
    <input type="text" class="form-control" id="title" name="title"
     placeholder="请输入标题">
   </div>
  </div>
  <div class="form-group">
   <label for="lastname" class="col-sm-2 control-label">类别</label>
   <div class="col-sm-3">
    <select class="form-control" name="categoryId">
     <option>1</option>
     <option>2</option>
     <option>3</option>
     <option>4</option>
     <option>5</option>
    </select>
   </div>
  </div>
  <div class="form-group">
   <label for="lastname" class="col-sm-2 control-label">内容</label>
   <div class=" col-sm-5">
    <textarea id="editor_id" name="details"
     class="form-control" >
    <strong>HTML内容</strong>
    </textarea>
   </div>
  </div>
  <div class="form-group">
   <div class="col-sm-offset-2 col-sm-10">
    <button type="submit" class="btn btn-default">保存草稿</button>
   </div>
  </div>
 </form>

</body>
</html>

KindAction.java

package com.leo.ows.action;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.UUID;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.springframework.stereotype.Controller;
import org.springframework.util.FileCopyUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;

import com.alibaba.fastjson.JSONObject;
@Controller
public class KindAction {

 @RequestMapping(value ="/Kindeditor/uploadFile", method = RequestMethod.POST)
 public void uploadFile(HttpServletRequest request, HttpServletResponse response) throws Exception {
  PrintWriter writer = response.getWriter();
  // 文件保存目录路径
  String savePath = request.getSession().getServletContext().getRealPath("/") + "upload/image" + File.separatorChar
     + File.separatorChar; 

  String saveUrl = request.getContextPath()+ File.separatorChar + "upload/image" + File.separatorChar
    + File.separatorChar; 

  // 定义允许上传的文件扩展名
  HashMap<String, String> extMap = new HashMap<String, String>();
  extMap.put("image", "gif,jpg,jpeg,png,bmp"); 

  // 最大文件大小
  long maxSize = 1000000;
  response.setContentType("text/html; charset=UTF-8"); 

  if (!ServletFileUpload.isMultipartContent(request)) {
   writer.println(getError("请选择文件。"));
   return;
  } 

  File uploadDir = new File(savePath);
  // 判断文件夹是否存在,如果不存在则创建文件夹
  if (!uploadDir.exists()) {
   uploadDir.mkdirs();
  } 

  // 检查目录写权限
  if (!uploadDir.canWrite()) {
   writer.println(getError("上传目录没有写权限。"));
   return;
  } 

  String dirName = request.getParameter("dir");
  if (dirName == null) {
   dirName = "image";
  }
  if (!extMap.containsKey(dirName)) {
   writer.println(getError("目录名不正确。"));
   return;
  } 

  MultipartHttpServletRequest mRequest = (MultipartHttpServletRequest) request;
  Map<String, MultipartFile> fileMap = mRequest.getFileMap();
  String fileName = null;
  for (Iterator<Map.Entry<String, MultipartFile>> it = fileMap.entrySet().iterator(); it.hasNext();) {
   Map.Entry<String, MultipartFile> entry = it.next();
   MultipartFile mFile = entry.getValue();
   fileName = mFile.getOriginalFilename();
   // 检查文件大小
   if (mFile.getSize() > maxSize) {
    writer.println(getError("上传文件大小超过限制。"));
    return;
   }
   String fileExt = fileName.substring(fileName.lastIndexOf(".")+1);
   if (!Arrays.<String> asList(extMap.get(dirName).split(",")).contains(fileExt)) {
    writer.println(getError("上传文件扩展名是不允许的扩展名。\n只允许" + extMap.get(dirName) + "格式。"));
    return;
   }
   UUID uuid = UUID.randomUUID();
   String path = savePath + uuid.toString() +"."+ fileExt;
   saveUrl = saveUrl + uuid.toString() +"."+ fileExt;
   BufferedOutputStream outputStream = new BufferedOutputStream(new FileOutputStream(path));
   FileCopyUtils.copy(mFile.getInputStream(), outputStream); 

   JSONObject obj = new JSONObject();
   obj.put("error", 0);
   obj.put("url", saveUrl);
   writer.println(obj.toString()); 

  }
 } 

 private String getError(String message) {
  JSONObject obj = new JSONObject();
  obj.put("error", 1);
  obj.put("message", message);
  return obj.toString();
 } 

 @RequestMapping(value = "/Kindeditor/fileManager", method = RequestMethod.GET)
 public void fileManager(HttpServletRequest request, HttpServletResponse response) throws Exception {
  //根目录路径,可以指定绝对路径,比如 /var/www/attached/
  String rootPath = request.getSession().getServletContext().getRealPath("/")+ "upload/";
  //根目录URL,可以指定绝对路径,比如 http://www.yoursite.com/attached/
  String rootUrl = request.getContextPath() + "/upload/";
  //图片扩展名
  String[] fileTypes = new String[]{"gif", "jpg", "jpeg", "png", "bmp"};
  System.out.println(rootPath);
  String dirName = request.getParameter("dir");
  if (dirName != null) {
   if(!Arrays.<String>asList(new String[]{"image", "flash", "media", "file"}).contains(dirName)){
    System.out.println("Invalid Directory name.");
    return;
   }
   rootPath += dirName + "/";
   rootUrl += dirName + "/";
   File saveDirFile = new File(rootPath);
   if (!saveDirFile.exists()) {
    saveDirFile.mkdirs();
   }
  }
  //根据path参数,设置各路径和URL
  String path = request.getParameter("path") != null ? request.getParameter("path") : "";
  String currentPath = rootPath + path;
  String currentUrl = rootUrl + path;
  String currentDirPath = path;
  String moveupDirPath = "";
  if (!"".equals(path)) {
   String str = currentDirPath.substring(0, currentDirPath.length() - 1);
   moveupDirPath = str.lastIndexOf("/") >= 0 ? str.substring(0, str.lastIndexOf("/") + 1) : "";
  }

  //排序形式,name or size or type
  String order = request.getParameter("order") != null ? request.getParameter("order").toLowerCase() : "name";

  //不允许使用..移动到上一级目录
  if (path.indexOf("..") >= 0) {
   System.out.println("Access is not allowed.");
   return;
  }
  //最后一个字符不是/
  if (!"".equals(path) && !path.endsWith("/")) {
   System.out.println("Parameter is not valid.");
   return;
  }
  //目录不存在或不是目录
  File currentPathFile = new File(currentPath);
  if(!currentPathFile.isDirectory()){
   System.out.println("Directory does not exist.");
   return;
  }

  //遍历目录取的文件信息
  List<Hashtable> fileList = new ArrayList<Hashtable>();
  if(currentPathFile.listFiles() != null) {
   for (File file : currentPathFile.listFiles()) {
    Hashtable<String, Object> hash = new Hashtable<String, Object>();
    String fileName = file.getName();
    if(file.isDirectory()) {
     hash.put("is_dir", true);
     hash.put("has_file", (file.listFiles() != null));
     hash.put("filesize", 0L);
     hash.put("is_photo", false);
     hash.put("filetype", "");
    } else if(file.isFile()){
     String fileExt = fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase();
     hash.put("is_dir", false);
     hash.put("has_file", false);
     hash.put("filesize", file.length());
     hash.put("is_photo", Arrays.<String>asList(fileTypes).contains(fileExt));
     hash.put("filetype", fileExt);
    }
    hash.put("filename", fileName);
    hash.put("datetime", new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(file.lastModified()));
    fileList.add(hash);
   }
  }

  if ("size".equals(order)) {
   Collections.sort(fileList, new SizeComparator());
  } else if ("type".equals(order)) {
   Collections.sort(fileList, new TypeComparator());
  } else {
   Collections.sort(fileList, new NameComparator());
  }
  JSONObject result = new JSONObject();
  result.put("moveup_dir_path", moveupDirPath);
  result.put("current_dir_path", currentDirPath);
  result.put("current_url", currentUrl);
  result.put("total_count", fileList.size());
  result.put("file_list", fileList);
  response.setContentType("application/json; charset=UTF-8");
  System.out.println(result.toJSONString());
  PrintWriter writer=response.getWriter();
  writer.println(result);
 }

 public class NameComparator implements Comparator {
  public int compare(Object a, Object b) {
   Hashtable hashA = (Hashtable)a;
   Hashtable hashB = (Hashtable)b;
   if (((Boolean)hashA.get("is_dir")) && !((Boolean)hashB.get("is_dir"))) {
    return -1;
   } else if (!((Boolean)hashA.get("is_dir")) && ((Boolean)hashB.get("is_dir"))) {
    return 1;
   } else {
    return ((String)hashA.get("filename")).compareTo((String)hashB.get("filename"));
   }
  }
 }
 public class SizeComparator implements Comparator {
  public int compare(Object a, Object b) {
   Hashtable hashA = (Hashtable)a;
   Hashtable hashB = (Hashtable)b;
   if (((Boolean)hashA.get("is_dir")) && !((Boolean)hashB.get("is_dir"))) {
    return -1;
   } else if (!((Boolean)hashA.get("is_dir")) && ((Boolean)hashB.get("is_dir"))) {
    return 1;
   } else {
    if (((Long)hashA.get("filesize")) > ((Long)hashB.get("filesize"))) {
     return 1;
    } else if (((Long)hashA.get("filesize")) < ((Long)hashB.get("filesize"))) {
     return -1;
    } else {
     return 0;
    }
   }
  }
 }
 public class TypeComparator implements Comparator {
  public int compare(Object a, Object b) {
   Hashtable hashA = (Hashtable)a;
   Hashtable hashB = (Hashtable)b;
   if (((Boolean)hashA.get("is_dir")) && !((Boolean)hashB.get("is_dir"))) {
    return -1;
   } else if (!((Boolean)hashA.get("is_dir")) && ((Boolean)hashB.get("is_dir"))) {
    return 1;
   } else {
    return ((String)hashA.get("filetype")).compareTo((String)hashB.get("filetype"));
   }
  }
 }

}

效果图

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • SpringMVC 单文件,多文件上传实现详解

    需要用到的流的相关知识:https://www.jb51.net/article/170640.htm SpringMVC中写好了文件上传的类. 要使用文件上传,首先需要文件上传相关的Jar包.commons-fileupload.jar 和 commons-io.jar. 添加到pom.xml或lib文件夹下. pom.xml: <dependency> <groupId>commons-fileupload</groupId> <artifactId>c

  • SpringMVC上传文件的两种方法

    在该示例中,阐述了SpringMVC如何上传文件. 1.上传页面upload.jsp <body> <form action="/TestSpringMVC3/data/uploadfile" enctype="multipart/form-data" method="post"> file:<input type="file" name="file"><br>

  • SpringMVC使用MultipartFile实现文件上传

    本文实例为大家分享了SpringMVC使用MultipartFile实现文件上传的具体代码,供大家参考,具体内容如下 一.配置文件 SpringMVC 用的是 的MultipartFile来进行文件上传 所以我们首先要配置MultipartResolver:用于处理表单中的file <!-- 配置MultipartResolver 用于文件上传 使用spring的CommosMultipartResolver --> <beans:bean id="multipartResol

  • SpringMVC实现多文件上传

    本文实例为大家分享了Spring MVC多文件上传的具体代码,供大家参考,具体内容如下 1)创建工程并导入JAR包 2)创建多文件选择页面 在 WebContent 目录下创建 JSP 页面 multiFiles.jsp,在该页面中使用表单上传多个文件,具体代码如下: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%&g

  • 通过简单步骤实现SpringMVC文件上传

    这篇文章主要介绍了通过简单步骤实现SpringMVC文件上传,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.创建文件上传FileController类 package com.byzore.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; im

  • SpringMVC+Ajax实现文件批量上传和下载功能实例代码

    今天做了文件的上传下载,小小总结一下,基本的web项目建立及SpringMVC框架搭建此处不详细写出来了. 上传form: <form id="uploadfiles" enctype="multipart/form-data"> <input type="file" multiple="multiple" id="file_upload" name="file_upload&q

  • SpringMVC图片文件跨服务器上传

    图片文件跨服务器上传(我使用的公司云桌面作为上传服务器,自己的笔记本作为存储服务器测试的) 一.上传服务器: 1.pom文件(使用jersey插件) <!-- 上传组件包 --> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version&g

  • 利用SpringMVC和Ajax实现文件上传功能

    个人根据相关资料实现利用SpringMVC和Ajax实现文件上传功能: 环境: 1.JDK1.7 2.maven3.3.9 3.Tomcat7 第一步: 导入相关jar包: 第二步: 配置springmvc-config.xml <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xml

  • springmvc+kindeditor文件上传实例详解

    本文实例为大家分享了springmvc+kindeditor文件上传的具体代码,供大家参考,具体内容如下 下载kindeditor 压缩包里面的jar放到tomcat的lib文件夹下,kindeditor文件放工程里,不用的可以删掉 jsp页面 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ ta

  • PHP文件上传实例详解!!!

    首先来看下上传部分的表单代码:   复制代码 代码如下: <form method="post" action="upload.php" enctype="multipart/form-data">        <table border=0 cellspacing=0 cellpadding=0 align=center width="100%">         <tr>       

  • VUE学习之Element-ui文件上传实例详解

    目录 引言 单文件上传 和表单一起上传 需求:需同时给后端传文件FormData和其他所需参数 数据的编码方式 补充:代理的使用 什么是代理?为什么要用代理 代理的使用 process.env.NODE_ENV 总结 引言 对于文件上传,在开发主要涉及到以下两个方面: 单个文件上传和表单一起实现上传(这种情况一般都是文件上传之后,后端返回保存在服务器的文件名,最后和我们的表单一起上传) 单文件上传 element-ui中的el-upload组件默认发送post请求,在使用upload组件自动携带

  • JS+Struts2多文件上传实例详解

    本文实例为大家分享了JS Struts2多文件上传的具体代码,供大家参考,具体内容如下 1.JSP页面: JS控制增加删除多个上传文件框,代码如下: <%@ page language="java" pageEncoding="UTF-8"%> <%@ taglib prefix="s" uri="/struts-tags"%> <!DOCTYPE html PUBLIC "-//W3C

  • java web图片上传和文件上传实例详解

    java web图片上传和文件上传 图片上传和文件上传本质上是一样的,图片本身也是文件.文件上传就是将图片上传到服务器,方式虽然有很多,但底层的实现都是文件的读写操作. 注意事项 1.form表单一定要写属性enctype="multipart/form-data" 2.为了能保证文件能上传成功file控件的name属性值要和你提交的控制层变量名一致, 例如空间名是file那么你要在后台这样定义 private File file; //file控件名 private String f

  • Bootstrap Fileinput 4.4.7文件上传实例详解

    本实例所做功能为发送带附件邮件,可以上传多个附件,操作为选择一个附件以后自动上传,然后继续选择附件,填写完表单其他信息,点击保存发送带附件邮件. HTML标签 <input id="fileUpload" type="file" name="file" data-show-preview="true" multiple/> js初始化,设置全局文件名参数 var fileName = []; function in

  • 基于Struts文件上传(FormFile)详解

    Struts中FormFile用于文件进行上传 1.在jsp文件中进行定义 <form action="/StrutsFileUpAndDown/register.do" method="post" enctype="multipart/form-data"> 名字:<input type="text" name="name" /> 头像:<input type="f

  • python中Django文件上传方法详解

    Django上传文件最简单最官方的方法 1.配置media路径 在settings.py中添加如下代码: MEDIA_ROOT = os.path.join(BASE_DIR, 'media') 2.定义数据表 import os from django.db import models from django.utils.timezone import now as timezone_now def upload_to(instance, filename):     now = timezo

  • JavaScript 使用Ckeditor+Ckfinder文件上传案例详解

    目录 一.准备工作 二.解压 三.开始集成 一.准备工作 Ckeditor_4.5.7_full + Ckfinder_java_2.6.0 二.解压 1.解压ckeditor,和平常文件解压相同,正常解压即可 2.解压ckfinder,解压完成后进入ckfinder文件夹下,发现有CKFinderJava-2.6.0.war文件,继续解压. 3.注意看红框部分 三.开始集成 1.准备工作完成,将图1中的ckeditor,及图3中的ckfinder文件夹拷贝到我们自己的项目的WebContent

  • php多个文件及图片上传实例详解

    本文实例讲述了php多个文件及图片上传的方法.分享给大家供大家参考.具体实现方法如下: 多个文件上传是在单文件上传的基础上利用遍历数组的方式进行遍历表单数组然后把文件一个个上传到服务器上了,下面就来看一个简单多个文件上传实例 多个文件上传和单独文件上传的处理方式是一样的,只需要在客户端多提供几个类型为"file"的输入表单,并指定不同的"name"属性值.例如,在下面的代码中,可以让用户同时选择三个本地文件一起上传给服务器,客户端的表单如下所示: 复制代码 代码如下

随机推荐