表单中文件上传问题

传统的方式:

<form id= "uploadForm" action= "http://localhost:8080/upload/addfile" method= "post" enctype ="multipart/form-data">  
     <p >指定文件名: <input type ="text" name="filename" /></p>  
     <p >上传文件: <input type ="file" name="file" /></p>  
     <input type ="submit" value="上传"/>  
</form>  

问题:这种提交,会导致表单页面刷新,若实际中该表单只是页面的一个模块,提交时,我们不希望页面刷新,这种方式就不行了。我们需要ajax异步提交。

 $.ajax({
            type: "POST",   
            url:"/upload/addfile",  
            data:$( '#uploadForm').serialize()                                                                                                                             
            async:false,
            error: function(request) {
            },
            success: function(data) {

            }

        });

上面这种提交只能提交一般的参数,若是文件是无法发送数据到后台的。

在网上找到解决办法:使用FormData对象

利用FormData对象,你可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个”表单”.

1 可以先创建一个空的FormData对象,然后使用append()方法向该对象里添加字段:

var formData = new FormData();  //空对象
forData.append("name","shiminghui");    //添加数据
 $.ajax({
            type: "POST",   
            url:"/upload/addfile",  
            data:forData,               //发送数据                                                                                                              
            async:false,
            processData: false,  // 告诉jQuery不要去处理发送的数据
            contentType: false   // 告诉jQuery不要去设置Content-Type请求头
            error: function(request) {
            },
            success: function(data) {

            }

        }); 

2 用一个已有的form元素来初始化FormData对象,只需要把这个form元素作为参数传入FormData构造函数

var formData = new FormData($("#uploadForm")); //若表单中有file输入域,也可以上传。

后台Controller代码 (基于SpringMVC),不过都一样:

@Controller("/upload"public class UPload{
    //使用Spring提供的通用的多部分解析器 CommonsMultipartResolver
    @RequestMapping(value = "/addfile")
    public void upload(HttpServletReqeust reqeust){
        CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver(request.getSession()
                .getServletContext());
        if (multipartResolver.isMultipart(request)) {
            MultipartHttpServletRequest multiRequest = multipartResolver.resolveMultipart(request);
            String filePath = null;
            //解析普通的表单参数
                Map<String, String> parmas = this.parse(multiRequest.getParameterMap());
            // 获取文件
            Iterator<String> iter = multiRequest.getFileNames();
            while (iter.hasNext()) {
                CommonsMultipartFile file = (CommonsMultipartFile) multiRequest.getFile(iter.next());
                //得到文件后具体的保存
                SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd");
            filePath += df.format(new Date()) + "/";
            String fileFormat = file.getOriginalFilename();
            filePath += fileFormat;
            File localFile = new File(filePath);
            if (!localFile.exists()) {
                localFile.mkdirs();
            }
            try {
                file.transferTo(localFile);
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            }
        }

    }
    private Map<String, String> parse(Map params) {
        if (params == null)
            return null;

        Map<String, String> result = new HashMap<String, String>();
        for (Object key : params.keySet()) {
            if (params.get(key) != null && params.get(key) instanceof String[]
                    && ((String[]) params.get(key)).length == 1) {
                result.put((String) key, ((String[]) params.get(key))[0]);
            }
        }
        return result;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值