upload_json.jsp 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
  2. <%@ page import="java.util.*,java.io.*" %>
  3. <%@ page import="java.text.SimpleDateFormat" %>
  4. <%@ page import="org.apache.commons.fileupload.*" %>
  5. <%@ page import="org.apache.commons.fileupload.disk.*" %>
  6. <%@ page import="org.apache.commons.fileupload.servlet.*" %>
  7. <%@ page import="org.json.simple.*" %>
  8. <%
  9. /**
  10. * KindEditor JSP
  11. *
  12. * 本JSP程序是演示程序,建议不要直接在实际项目中使用。
  13. * 如果您确定直接使用本程序,使用之前请仔细确认相关安全设置。
  14. *
  15. */
  16. //文件保存目录路径
  17. String savePath = pageContext.getServletContext().getRealPath("/") + "attached/";
  18. //文件保存目录URL
  19. String saveUrl = request.getContextPath() + "/attached/";
  20. //定义允许上传的文件扩展名
  21. HashMap<String, String> extMap = new HashMap<String, String>();
  22. extMap.put("image", "gif,jpg,jpeg,png,bmp");
  23. extMap.put("flash", "swf,flv");
  24. extMap.put("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb,mp4");
  25. extMap.put("file", "doc,docx,xls,xlsx,ppt,txt,zip,rar,gz,bz2");
  26. //最大文件大小
  27. long maxSize = 1000000000;
  28. response.setContentType("text/html; charset=UTF-8");
  29. if(!ServletFileUpload.isMultipartContent(request)){
  30. out.println(getError("请选择文件。"));
  31. return;
  32. }
  33. //检查目录
  34. File uploadDir = new File(savePath);
  35. if(!uploadDir.isDirectory()){
  36. out.println(getError("上传目录不存在。"));
  37. return;
  38. }
  39. //检查目录写权限
  40. if(!uploadDir.canWrite()){
  41. out.println(getError("上传目录没有写权限。"));
  42. return;
  43. }
  44. String dirName = request.getParameter("dir");
  45. if (dirName == null) {
  46. dirName = "image";
  47. }
  48. if(!extMap.containsKey(dirName)){
  49. out.println(getError("目录名不正确。"));
  50. return;
  51. }
  52. //创建文件夹
  53. savePath += dirName + "/";
  54. saveUrl += dirName + "/";
  55. File saveDirFile = new File(savePath);
  56. if (!saveDirFile.exists()) {
  57. saveDirFile.mkdirs();
  58. }
  59. SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
  60. String ymd = sdf.format(new Date());
  61. savePath += ymd + "/";
  62. saveUrl += ymd + "/";
  63. File dirFile = new File(savePath);
  64. if (!dirFile.exists()) {
  65. dirFile.mkdirs();
  66. }
  67. FileItemFactory factory = new DiskFileItemFactory();
  68. ServletFileUpload upload = new ServletFileUpload(factory);
  69. upload.setHeaderEncoding("UTF-8");
  70. List items = upload.parseRequest(request);
  71. Iterator itr = items.iterator();
  72. while (itr.hasNext()) {
  73. FileItem item = (FileItem) itr.next();
  74. String fileName = item.getName();
  75. long fileSize = item.getSize();
  76. if (!item.isFormField()) {
  77. //检查文件大小
  78. if(item.getSize() > maxSize){
  79. out.println(getError("上传文件大小超过限制。"));
  80. return;
  81. }
  82. //检查扩展名
  83. String fileExt = fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase();
  84. if(!Arrays.<String>asList(extMap.get(dirName).split(",")).contains(fileExt)){
  85. out.println(getError("上传文件扩展名是不允许的扩展名。\n只允许" + extMap.get(dirName) + "格式。"));
  86. return;
  87. }
  88. SimpleDateFormat df = new SimpleDateFormat("yyyyMMddHHmmss");
  89. String newFileName = df.format(new Date()) + "_" + new Random().nextInt(1000) + "." + fileExt;
  90. try{
  91. File uploadedFile = new File(savePath, newFileName);
  92. item.write(uploadedFile);
  93. }catch(Exception e){
  94. out.println(getError("上传文件失败。"));
  95. return;
  96. }
  97. JSONObject obj = new JSONObject();
  98. obj.put("error", 0);
  99. obj.put("url", saveUrl + newFileName);
  100. out.println(obj.toJSONString());
  101. }
  102. }
  103. %>
  104. <%!
  105. private String getError(String message) {
  106. JSONObject obj = new JSONObject();
  107. obj.put("error", 1);
  108. obj.put("message", message);
  109. return obj.toJSONString();
  110. }
  111. %>