文件上传的步骤

文件上传的步骤:
1.<input type="file" />
2.首先要更改form的enctype="multipart/form-data"
表示向服务器传输的过程中以二进制的方式传输
默认传输类型: enctype="application/x-www-form-urlencoded"
3.相关jar包 下载地址 www.apache.org
commons-fileupload-1.2.1.jar 核心组件包
commons-io-2.0.1.jar --fileupload组件包,依赖了IO
commons-lang3-3.1.jar
commons-logging-1.1.3.jar

json-lib-2.4-jdk15.jar JSON工具类
struts2-json-plugin-2.3.15.1.jar

4.普通上传页面

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>

    <title>文件上传的开发</title>
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <!--
    <link rel="stylesheet" type="text/css" href="styles.css">
    -->
  </head>

  <body>
    <form action="upload/uploadAction.jsp?dirpath=pipi" method="post" enctype="multipart/form-data">
        <p><input type="text" name="username" value="pipi" /></p>
        <p><input type="file" name="file000" /></p>
        <input type="submit" value="提交" />
    </form>

  </body>
</html>

5.ajax上传页面

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML>
<html>
  <head>

    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>ajax文件上传的开发</title>
    <meta name="keywords" content="" />
    <meta name="description" content="" />
    <!--
    <link rel="stylesheet" type="text/css" href="styles.css">
    -->
    <style type="text/css">
        #percent{width:600px;height:30px;position:relative;border:1px solid green;}
        #percent #per{height:30px;background:green;position:absolute;left:0;top:0;}
    </style>
  </head>

  <body>
    <form action="upload/uploadAction.jsp?dirpath=pipi" method="post" enctype="multipart/form-data">
        <a href="javascript:;" class="uploadbtn" onclick="openFileDialog()">文件上传</a>
        <input type="file" name="file" id="file" onchange="uploadFile()" style="display: none;" />
        <input type="submit" value="提交" />
    </form>

    <img id="showImg" width="160" height="120" />
    <ul id="showlist">

    </ul>

    <div id="percent">
        <div id="per"></div>
    </div>
    <div id="pnum"></div>
    <script type="text/javascript">
        function openFileDialog(){
            var ie = navigator.appName == "Microsoft Internet Explorer"?true:false;
            if(ie){
                //如果是ie浏览器
                document.getElementById("file").click();
            }else{
                //自定义事件es5中的内容
                var a = document.createEvent("MouseEvents");
                a.initEvent("click",true,true);
                document.getElementById("file").dispatchEvent(a);
            }
        };

        //ajax文件上传  不支持低版本浏览器
        function uploadFile(){
            //拿到文件上传的队列
            var files = document.getElementById("file").files
            var file = files[0];

            var type = file.type;//文件类型
            var name = file.name;//文件名称
            var size = file.size;//文件大小
            if(type.indexOf("image") == -1) {
                alert("请上传图片类型")
                return;
            }
            //alert(file.name+"===="+file.size+"==="+file.type);
            showImage(file,function(data){
                document.getElementById("showImg").src=data;
            })

            var form = new FormData();
            form.append("file",file);

            //如何传输给服务器端,进度条
            var xhr = new XMLHttpRequest();
            //请求服务器
            xhr.open("post", "upload/uploadAction.jsp?dirpath=pipi",true);
            xhr.onreadystatechange = function(){
                if(this.readyState == 4 && this.status == 200){
                    var data = this.responseText;

                    var jsonData = eval("("+data+")");
                    var html = "";
                    for(var i=0;i<jsonData.length;i++){
                        html += "<li>"+jsonData[i].name+"===="+jsonData[i].sizeString+"====<img src=‘"+jsonData[i].url+"‘ width=‘50‘ height=‘50‘/>"
                    }
                    console.log(data);
                    document.getElementById("showlist").innerHTML += html;
                }
            };

            xhr.upload.addEventListener("progress", progressFunction,false);
            xhr.send(form);

        }

        //进度条
        function progressFunction(evt){
        console.log("------");
            var perDom = document.getElementById("per");
            if(evt.lengthComputable){
                //evt.loaded已经上传了多少
                //event.total上传文件的总大小
                var p = evt.loaded / event.total;
                console.log(p);
                var pnum = Math.floor(p*100) +"%";
                perDom.style.width = pnum;
                document.getElementById("pnum").innerHTML = pnum;
            }
        }

        /*图片预览*/
        function showImage(f,callback){
            var reader = new FileReader();
            reader.onload = (function(theFile) {
                return function(e) {
                    // img 元素
                    if(callback)callback(e.target.result);
                };  

            })(f);
            reader.readAsDataURL(f);
        };    

    </script>
  </body>
</html>

6.后台处理类

<%@page import="org.apache.struts2.json.JSONUtil"%>
<%@page import="com.rui.util.StrUtils"%>
<%@page import="java.io.File"%>
<%@page import="org.apache.commons.fileupload.FileItem"%>
<%@page import="org.apache.commons.fileupload.servlet.ServletFileUpload"%>
<%@page import="org.apache.commons.fileupload.disk.DiskFileItemFactory"%>
<%@page import="org.apache.commons.fileupload.FileItemFactory"%>
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%

    /*文件上传的方式*/

    //1.获取文件上传的工厂类
    FileItemFactory factory = new DiskFileItemFactory();
    //2.解析上传文件的工厂
    ServletFileUpload fileUpload = new ServletFileUpload(factory);
    //3.通过解析类解析request对象中的二进制文件
    List<FileItem> fileItems = fileUpload.parseRequest(request);
    //4.读取二进制文件,写入服务器

    //获取服务器的路径getRealPath()获取当前项目所在服务器的根目录
    //D:\tool\dev\apache-tomcat-7.0.56-windows-x86\apache-tomcat-7.0.56\me-webapps\fileUpload\resource
    String dirpath = request.getParameter("dirpath");//
    if(StrUtils.isEmpty(dirpath)) dirpath = "default";
    String fpath = "resource/"+dirpath;
    String path = request.getRealPath(fpath);
    File rootPath = new File(path);
    //如果目录不存在就动态创建
    if(!rootPath.exists()){
        rootPath.mkdirs();
    }

    //如果有文件,就开始进行读和写
    if(fileItems != null && fileItems.size()>0){
        List<Map<String,Object>> maps = new ArrayList<Map<String,Object>>();
        for(FileItem fileItem : fileItems){
            if(!fileItem.isFormField()){//判断是不是file表单
                //获取文件名称
                String filename = fileItem.getName();
                //文件大小
                long filesize = fileItem.getSize();
                //获取文件后缀
                String ext = StrUtils.getExt(filename, true);
                //重构文件的名称===头像上传的原理就是文件的覆盖
                String fname = UUID.randomUUID().toString()+ext;
                File fileName = new File(rootPath,fname);
                fileItem.write(fileName);

                Map<String,Object> map = new HashMap<String,Object>();
                map.put("name", filename);
                map.put("size", filesize);
                map.put("sizeString", StrUtils.countFileSize(filesize));
                map.put("url", fpath+"/"+fname);
                maps.add(map);

            }
        }
        out.print(JSONUtil.serialize(maps));
    }else {
        out.print("");
        //response.sendRedirect("fail.jsp");
    }
    //5.在服务器创建一个上传的目录
    //6.开始写入
    //7.返回数据

    //response.sendRedirect("success.jsp");

 %>

7.工具类

package com.rui.util;

import java.text.DateFormat;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;

/**
 *
 * @ClassName: StrUtils
 * @Description: 工具类
 * @author poseidon
 * @date 2015年10月23日 下午8:13:45
 * @version V1.0.0
 */
public class StrUtils {

    /**
     *
     * @Title: isEmpty
     * @Description: 空判断
     * @param content
     * @return boolean
     */
    public static boolean isEmpty(String content){
        return (content==null || content.equals(""))?true:false;
    }

    /**
     *
     * @Title: isNotEmpty
     * @Description: 非空判断
     * @param content
     * @return boolean
     */
    public static boolean isNotEmpty(String content){
        return !isEmpty(content);
    }

    /**
     *
     * @Title: formatDate
     * @Description: 格式化日期类
     * @param date
     * @param pattern
     * @return String
     */
    public static String formatDate(Date date,String pattern){
        if(date!=null){
            String dateString = new SimpleDateFormat(pattern).format(date);
            return dateString;
        }else{
            return "";
        }
    }

    /**
     *
     * @Title: getExt
     * @Description: 获取文件的后缀
     * @param name 文件名称
     * @param flag true有点false没点
     * @return String
     */
    public static String getExt(String name,boolean flag){
        if(isNotEmpty(name)){
            String ext  = null;
            if(flag){
                ext = name.substring(name.lastIndexOf("."), name.length());
            }else{
                ext = name.substring(name.lastIndexOf(".")+1, name.length());
            }
            return ext;
        }else{
            return "";
        }
    }

    /**
     *
     * @Title: generateFileName
     * @Description: 为上传文件自动分配文件名称,避免重复
     * @param fileName
     * @param randomNum
     * @param dataPattern
     * @return String
     */
    public static String generateFileName(String fileName,int randomNum,String dataPattern) {
        // 获得当前时间
        DateFormat format = new SimpleDateFormat(dataPattern);
        // 转换为字符串
        String formatDate = format.format(new Date());
        // 随机生成文件编号
        int random = new Random().nextInt(randomNum);
        // 获得文件后缀名称
        int position = fileName.lastIndexOf(".");
        String extension = fileName.substring(position);
        // 组成一个新的文件名称
        return formatDate + random + extension;
    }

    /**
     *
     * @Title: countFileSize
     * @Description: 根据File文件的长度统计文件的大小
     * @param fileSize
     * @return String
     */
    public static String countFileSize(long fileSize) {
        String fileSizeString = "";
        try {
            DecimalFormat df = new DecimalFormat("#.00");
            long fileS = fileSize;
            if (fileS == 0) {
                fileSizeString = "0KB";
            } else if (fileS < 1024) {
                fileSizeString = df.format((double) fileS) + "B";
            } else if (fileS < 1048576) {
                fileSizeString = df.format((double) fileS / 1024) + "KB";
            } else if (fileS < 1073741824) {
                fileSizeString = df
                        .format(((double) fileS / 1024 / 1024) - 0.01)
                        + "MB";
            } else {
                fileSizeString = df.format((double) fileS / 1024 / 1024 / 1024)
                        + "G";
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return fileSizeString;
    }

    /**
     *
     * @Title: conversionSpecialCharacters
     * @Description: 把两个反斜线转换成正斜线
     * @param string
     * @return String
     */
    public static String conversionSpecialCharacters(String string) {
        return string.replaceAll("\\\\", "/");
    }

    public static void main(String[] args) {

    }
}
时间: 2025-01-04 08:17:05

文件上传的步骤的相关文章

文件上传(java web)

文件上传: 对表单的要求: * method="post" * enctype="multipart/form-data" * 表单中需要添加文件表单项:<input type="file" name="xxx" /> 对Servlet的要求: * request.getParametere("xxx");这个方法在表单为enctype="multipart/form-data&quo

【SpringMVC学习08】SpringMVC中实现文件上传

之前有写过一篇struts2实现的文件上传,这一篇博文主要来总结下springmvc实现文件上传的步骤.首先来看一下单个文件的上传,然后再来总结下多个文件上传. 1. 环境准备 springmvc上传文件的功能需要两个jar包的支持(点我下载),如下 2. 单个文件的上传 2.1 前台页面 简单的写一下前台页面,注意一点的是form表单中别忘了写enctype="multipart/form-data"属性: <tr> <td>商品图片</td> &

web文件上传

文件上传的步骤: 1.目前Java文件上传功能都是依靠Apache组织的commons-io, fileupload两个包来实现的: 2. http://commons.apache.org/下载io,fileupload包 添加到项目中的WEB-INF/lib文件夹下: 3.文件上传的时候文件一般是存在服务器的upload目录下,文件名称 存储在数据库中,为了防止上传的文件同名,我们需要动态的 修改上传文件的名称.  4.必须设计form表单类型为(请求方式为:post请求,添加属性encty

一个异步文件上传的方式

不是我写的,我看了他的,思路很明确: 实现思路: 在js脚本中动态创建form,动态创建form中的内容,将文件上传的内容以隐藏域的方式提交过去,然后写好回调等. 感觉思路不难,但是我写不出来,感觉需要对于url,http有一定了解,js也ok才可. 代码: 上传的js: // JavaScript Document jQuery.extend({ createUploadIframe: function(id, uri) { //create frame var frameId = 'jUpl

iOS开发——网络编程OC篇&amp;(七)文件上传

一.文件上传的步骤1.设置请求头* 目的:告诉服务器请求体里面的内容并非普通的参数,而是包含了文件参数[request setValue:@"multipart/form-data; boundary=iCocos" forHTTPHeaderField:@"Content-Type"]; 2.设置请求体* 作用:存放参数(文件参数和非文件参数)1> 非文件参数[body appendData:iCocosEncode(@"--iCocos\r\n&

Struts2系列:(11)文件上传

生活赋予我们一种巨大的和无限高贵的礼品,这就是青春:充满着力量,充满着期待,充满着求知,充满着希望. Struts 2使用FileUpload 拦截器和 Commons FileUpload 组件实现文件上传. FileUploadInterceptor 全名:org.apache.struts2.interceptor.FileUploadInterceptor Interceptor that is based off(基于) of MultiPartRequestWrapper,  whi

servlet+jsp实现的文件上传与下载

java文件上传与下载 通过微表单元苏设置Method = "post" enctype = "multipart/form-data"属性,让表单提交的数据以二进制编码的方式提交,在接收此请求的Servlet 中用二进制流来获取内容,就可以取得上传文件的内容,从而实现文件的上传. 表单ENCTYPE属性 application/x-www-form-urlencoded :这是默认的编码方式,它只处理表单域里的value属性值.采用 这种编码方式的表单会将表单域的

Servlet实现文件上传,可多文件上传

一.Servlet实现文件上传,需要添加第三方提供的jar包 下载地址: 1) commons-fileupload-1.2.2-bin.zip      :   点击打开链接 2) commons-io-2.3-bin.zip                       :    点击打开链接 接着把这两个jar包放到 lib文件夹下: 二: 文件上传的表单提交方式必须是POST方式, 编码类型:enctype="multipart/form-data",默认是 applicatio

深入分析JavaWeb 47 -- Struts2拦截器与文件上传下载

一.struts2中的拦截器(框架功能核心) 1.过滤器VS拦截器 过滤器VS拦截器功能是一回事.过滤器是Servlet规范中的技术,可以对请求和响应进行过滤. 拦截器是Struts2框架中的技术,实现AOP(面向切面)的编程思想,是可插拔的, 可以对访问某个 Action 方法之前或之后实施拦截. 拦截器栈(Interceptor Stack): 将拦截器按一定的顺序联结成一条链. 在访问被拦截的方法时, Struts2拦截器链中的拦截器就会按其之前定义的顺序被依次调用 Struts2执行原理