后台(27)——文件上传
2017-02-27 22:24
78 查看
探索Android软键盘的疑难杂症
深入探讨Android异步精髓Handler
详解Android主流框架不可或缺的基石
站在源码的肩膀上全解Scroller工作机制
Android多分辨率适配框架(1)— 核心基础
Android多分辨率适配框架(2)— 原理剖析
Android多分辨率适配框架(3)— 使用指南
自定义View系列教程00–推翻自己和过往,重学自定义View
自定义View系列教程01–常用工具介绍
自定义View系列教程02–onMeasure源码详尽分析
自定义View系列教程03–onLayout源码详尽分析
自定义View系列教程04–Draw源码分析及其实践
自定义View系列教程05–示例分析
自定义View系列教程06–详解View的Touch事件处理
自定义View系列教程07–详解ViewGroup分发Touch事件
自定义View系列教程08–滑动冲突的产生及其处理
作者博客地址:http://blog.csdn.net/lfdfhl
但是请注意该表单必须满足如下三个条件:
form的method必须是post
form的enctype必须是multipart/form-data
form中利用input type=”file”提供上传的入口
使用Commons-fileupload需要导入两个jar包:
commons-fileupload
commons-io
运行后效果如下图所示:
再来写一个处理文件上传的Servlet
嗯哼,鉴于该示例比较简单和代码里已有的注释,在此不再对代码作详解。
将保存上传文件的目录放在用户直接访问不到的地方,比如WEB-INF
上传文件重名的处理,可用UUID+文件名的方式
将上传文件合理地存入子目录中,比如按照日期
限制上传文件的大小,比如3M
深入探讨Android异步精髓Handler
详解Android主流框架不可或缺的基石
站在源码的肩膀上全解Scroller工作机制
Android多分辨率适配框架(1)— 核心基础
Android多分辨率适配框架(2)— 原理剖析
Android多分辨率适配框架(3)— 使用指南
自定义View系列教程00–推翻自己和过往,重学自定义View
自定义View系列教程01–常用工具介绍
自定义View系列教程02–onMeasure源码详尽分析
自定义View系列教程03–onLayout源码详尽分析
自定义View系列教程04–Draw源码分析及其实践
自定义View系列教程05–示例分析
自定义View系列教程06–详解View的Touch事件处理
自定义View系列教程07–详解ViewGroup分发Touch事件
自定义View系列教程08–滑动冲突的产生及其处理
版权声明
本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl
文件上传概述
文件上传通常指的是用户在浏览器中通过表单form将文件上传至服务端但是请注意该表单必须满足如下三个条件:
form的method必须是post
form的enctype必须是multipart/form-data
form中利用input type=”file”提供上传的入口
Commons-fileupload简介
Commons-fileupload是Apache提供的一个用来处理表单文件上传的一个开源组件。该组件操作简单、API通俗易懂、性能优异。使用Commons-fileupload需要导入两个jar包:
commons-fileupload
commons-io
Commons-fileupload使用示例
我们先来准备一个表单form<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>文件上传</title> </head> <body> <form enctype="multipart/form-data" action="${pageContext.request.contextPath }/servlet" method="post" > 文件描述:<input type="text" name="description"/><br/><br/> 选择文件:<input type="file" name="photo"/><br/><br/> <input type="submit" value="上传"/><br/><br/> </form> </body> </html>
运行后效果如下图所示:
再来写一个处理文件上传的Servlet
/** * 本文作者:谷哥的小弟 * 博客地址:http://blog.csdn.net/lfdfhl */ package cn.com; import java.io.File; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.List; import java.util.UUID; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; import org.apache.commons.io.FilenameUtils; public class UploadServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 判断表单是否支持文件上传 boolean isMultipartContent = ServletFileUpload.isMultipartContent(request); if (isMultipartContent) { DiskFileItemFactory factory = new DiskFileItemFactory(); ServletFileUpload servletFileUpload = new ServletFileUpload(factory); servletFileUpload.setHeaderEncoding("UTF-8"); try { //得到并处理表单中的每个项 List<FileItem> fileItems = servletFileUpload.parseRequest(request); for (FileItem fileitem : fileItems) { if (fileitem.isFormField()) { processFormField(fileitem); } else { processUploadField(fileitem); } } } catch (Exception e) { e.printStackTrace(); } } } // 处理普通表单项 private void processFormField(FileItem fileitem) { try { String fieldName = fileitem.getFieldName(); String fieldValue = fileitem.getString("UTF-8"); System.out.println(fieldName + "=" + fieldValue); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } } //处理上传表单项 private void processUploadField(FileItem fileItem) { try { //创建存放上传文件的目录 String folderName="upload"; String folderPath = getServletContext().getRealPath("/WEB-INF/"+folderName); File folder = new File(folderPath); if (!folder.exists()) { folder.mkdirs(); } //生成不重复的文件名 String fileName = fileItem.getName(); if (fileName != null) { fileName = FilenameUtils.getName(fileName); } fileName = UUID.randomUUID() + "_" + fileName; //按照日期生成子文件名称 String dateDirectory = makeDateDirectory(folder); //存放被上传的文件 File file=new File(folder, dateDirectory + File.separator + fileName); fileItem.write(file); } catch (Exception e) { e.printStackTrace(); } } //依据日期生成子文件夹 private String makeDateDirectory(File folder) { SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); Date date=new Date(); String dateDirectory = simpleDateFormat.format(date); File file = new File(folder, dateDirectory); if (!file.exists()) { file.mkdirs(); } return dateDirectory; } }
嗯哼,鉴于该示例比较简单和代码里已有的注释,在此不再对代码作详解。
文件上传的注意事项
实际开发中,在处理文件上传时请注意以下问题:将保存上传文件的目录放在用户直接访问不到的地方,比如WEB-INF
上传文件重名的处理,可用UUID+文件名的方式
将上传文件合理地存入子目录中,比如按照日期
限制上传文件的大小,比如3M
相关文章推荐
- 【原创】Ext 上传文件,前后台实现, Asp.net 代码
- Ext 上传文件,前后台实现, Asp.net 代码
- sturts2上传文件,后台获取不到文件!
- JAVA 文件上传后台判断浏览器的类型以及JDK1.5和1.6处理的不同
- flash8上传文件后台代码-.Net,php,cf
- WEB环境中后台自动上传文件至数据库的实现
- 网站后台上传与FTP上传文件
- 解决:上传文件按钮样式,fileupload 样式,同时解决后台得不到上传文件的信息问题
- 关于文件上传的后台处理
- Ext 上传文件,前后台实现, Asp.net 代码
- AjaxFileUpLoad 文件异步上传Demo(模仿官方网站,后台使用.net一般处理程序)
- 用asp.net mvc写一个后台文件上传
- ajax实现文件上传以及后台servlet中的处理总结
- 后台上传大文件超时处理
- 解决无耻迅雷在后台偷偷上传文件的一种方法
- 用asp.net mvc写一个后台文件上传
- 购物网站27:FORM-上传文件
- PHPNow下安装ECshop后后台提示: 您的服务器设置了 open_base_dir 且没有包含 C:\WINDOWS\Temp,您将无法上传文件。 解决方法
- 文件上传后台和前台代码(文件下载也是)
- Ext+struts+java 文件上传 后台乱码解决!