@RequestMapping("/insertOrder")

@ResponseBody

public  Object insertOrder(String userId,HttpServletRequest req) {

MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;             // 获得文件:         MultipartFile file = multipartRequest.getFileMap();

String path = req.getSession().getServletContext().getRealPath("/");
        System.out.println(path);
        String filepath = "business/water/images/";
        String picturepath = "";
        if(file!=null){
            picturepath =filepath+getTimeName()+file.getOriginalFilename();
        }
        FileUtil.SaveFileFromInputStream(file.getInputStream(), path+picturepath);
        dto.setPhotos(picturepath);
        resp.setContentType("text/html");

}

********************************************************************************************

jsp中的form表单的enctype必须附带

<form action="/api/v1.0/tests/testfile" httpMethod="post" enctype="multipart/form-data">
  <input type="file" name="testfile"/>
  <button type="submit">提交</button>
</form>
 
 
***********************************************************************************
  首先要说的就是 ajax 是无法实现上传文件的,可以想一下ajax与后台通信都是通过传递字符串,怎么能传递文件呢?其实出于安全考虑js是不能操作文件的,所以就不要再说用ajax来实现文件的上传了,这是不可能的。

而本文实现的文件上传也是无页面刷新的,可以说是一种"类似AJAX"方法。

开始之前先说两句无关的,其实在ajax出现之前,web应用也可以是无刷新的,那时大多通过IFrame来做到这一点。当然Ajax出现之后,人们一窝蜂地投奔Ajax 的阵营了,iFrame 就乏人问津了。但是用iFrame来实现无刷新上传文件确实一个很好的选择。ps:Ajax技术基本上可以说是由google公司带起来的,但少Gmail中上传文件用的还是 IFrame,所以说使用IFrame来上传文件是最好的选择。

我在这里这里用的技术是jsp,其实asp,php等也是一样可以这么实现的

一共两个文件就可实现:index.html 和 upload.jsp,在这里讲解一下

index.html

<html>

<body>

<form action="upload.jsp" id="form1" name="form1" encType="multipart/form-data"  method="post"       target="hidden_frame" >

<input type="file" id="file" name="file" style="width:450">

<INPUT type="submit" value="上传文件"><span id="msg"></span>

<br>

<font color="red">支持JPG,JPEG,GIF,BMP,SWF,RMVB,RM,AVI文件的上传</font>

<iframe name='hidden_frame' id="hidden_frame" style='display:none'></iframe>

</form>

</body>

</html>

<script type="text/javascript">

function callback(msg)

{

document.getElementByIdx_x_x_x_x_x("file").outerHTML = document.getElementByIdx_x_x_x_x_x("file").outerHTML;

document.getElementByIdx_x_x_x_x_x("msg").innerHTML = "<font color=red>"+msg+"</font>";

}

</script>

index.html 中主要要做的就是写一个 form 和 iframe ,并把 form 的 target 设为 iframe 的名字,注意要把 iframe 设为不可见,其他的都是正常的文件上传的写法,这样刷新的页面就是这个隐藏的 Iframe ,而在 index.html 中是不会有页面刷新的,js的 callback 方法是回调方法。用于清空文件上传框和显示后台信息,注意清空文件上传框的方法,和普通方法有点不一样。

--upload.jsp

<%@ page language="java" contentType="text/html; charset=gb2312" %>

<%@ page import="com.jspsmart.upload.SmartUpload"%>

<%

//新建一个SmartUpload对象

SmartUpload su = new SmartUpload();

//上传初始化

su.initialize(pageContext);

// 设定上传限制

//1.限制每个上传文件的最大长度。

su.setMaxFileSize(10000000);

//2.限制总上传数据的长度。

su.setTotalMaxFileSize(20000000);

//3.设定允许上传的文件(通过扩展名限制),仅允许doc,txt文件。

su.setAllowedFilesList("doc,txt,jpg,rar,mid,waw,mp3,gif");

boolean sign = true;

//4.设定禁止上传的文件(通过扩展名限制),禁止上传带有exe,bat,jsp,htm,html扩展名的文件和没有扩展名的文件。

try {

su.setDeniedFilesList("exe,bat,jsp,htm,html");

//上传文件

su.upload();

//将上传文件保存到指定目录

su.save("c:\\");

} catch (Exception e) {

e.printStackTrace();

sign = false;

}

if(sign==true)

{

out.println("<script>parent.callback('upload file success')</script>");

}else

{

out.println("<script>parent.callback('upload file error')</script>");

}

%>

upload.jsp 中只要注意最后输出的格式就可以了。其实原理就是输出一段js代码到 iframe 中,然后在iframe中来控制它的父页面。

OK,至此一个无刷新的页面上传组件就做好了,不要忘了在 WEB-INF/lib 下加上必须的 jspSmartUpload.jar 包。

需要说明的是使用Iframe来上传,状态栏还是会有刷新的,因为iframe 中的页面刷新了嘛,但是外部页面,就是你所看到的页面是没有刷新的,所以也可以说是类似Ajax上传。

SpringMVC在上传文件的时候提示The current request is not a multipart request错误的更多相关文章

  1. 基于SpringMVC的上传文件实现

    基于SpringMVC的上传文件实现 1.项目源码 源码地址:upload 2.关键代码 @RequestMapping("/upload2") public void datal ...

  2. 【SpringMVC】使用SpringMVC进行上传文件!

    写在前面: 之前在上传文件的时候,使用的是commons-file-upload这个插件,非常方便,能控制每个文件的大小,总共大小,缓存,以及支持多个文件的同时上传,但是写一次上传文件的后台代码量太大 ...

  3. SpringMVC 之 上传文件

    一.需求: 利用SpringMVC实现上传文件的功能 二.思路: 1.我们可以在SpringMVC中,通过配置一个MultipartResolver来上传文件. 2.通过MultipartFile f ...

  4. springmvc+ajaxFileUpload上传文件(前后台彻底分离的情况下)

    首先是导入jar包: web.xml: <servlet> <servlet-name>mvc-dispatcher</servlet-name> <serv ...

  5. SpringMVC 学习-上传文件分解器 CommonsMultipartResolver 类

    Spring 组件 CommonsMultipartResolver 类的主要作用是配置文件上传的一些属性,也可以控制上传文件的大小. 在 springmvc-servlet.xml 配置文件中: & ...

  6. SpringMvc(注解)上传文件的简单例子

    spring mvc(注解)上传文件的简单例子,这有几个需要注意的地方1.form的enctype=”multipart/form-data” 这个是上传文件必须的2.applicationConte ...

  7. 为什么上传文件的表单里面要加一个属性enctype=multipart/form-data?

    首先知道enctype这个属性管理的是表单的MIME编码.共有三个值可选:1.application/x-www-form-urlencoded2.multipart/form-data3.text/ ...

  8. Spring使用mutipartFile上传文件报错【Failed to instantiate [org.springframework.web.multipart.MultipartFile]】

    报错场景: 使用SSM框架实现文件上传时报“Failed to instantiate [org.springframework.web.multipart.MultipartFile]”错,控制器源 ...

  9. springmvc.xml 上传文件的配置

    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.Comm ...

随机推荐

  1. 对 const char* const &a 的理解

    定义中用到&是独立引用. 比如: char i; char &a=i; 表示a是i的一个单独引用. 当有i='a'时,也有a='a'; 当有a='c'时,也有i='c'; 两个变量的标 ...

  2. cocos2dx解析lua table数据结构 简易版.

    之前一直用xml填配置, cocos2dx自带了xml解析接口, 非常方便. 但是, 接口好用也改变不了xml的结构字符太多, 书写麻烦, 乱七八糟的事实. 很早就想换lua, 无奈引擎没有现成接口, ...

  3. WHU 1568 Product (DP、逆元)

    题意: 定义f(x) 为数x的所有数字的乘积. 求满足f(k)=f(x)的不同的不含数字1的k的个数. x的长度小于50. 不超过1000组数据. Solution: 由于函数是乘积的形式,可以由质因 ...

  4. window下配置SSH连接GitHub、GitHub配置ssh key(转)

    转自:http://jingyan.baidu.com/article/a65957f4e91ccf24e77f9b11.html 此经验分两部分: 第一部分介绍:在windows下通过msysGit ...

  5. git学习小结 (笔记)

    Modesty helps one to go forward, whereas conceit makes one lag behind. "虚心使人进步,骄傲使人落后" 注:本 ...

  6. php把文件上传到远程服务器上例子

    在这里我们利用curl实现把本地服务器的文件通过curl发送请求给远程服务器的php文件接受就实现了上传,还一个是利用ftp来上传方法也是php中的curl操作ftp服务器进行上传. 我这里写的是用c ...

  7. ArcGis Engine 读取自定义prj坐标系文件时,中文名称乱码

    今天测试时发现使用ArcMap自定义一个坐标系,将坐标系名称设置为中文,基准面名称选择为自定义后,然后保存成prj文件. 在自己的程序中读取该prj文件后,发现ISpatialReference 对象 ...

  8. glide简介

    golang包管理工具glide简介   golang包管理工具glide简介 前言 golang是一个十分有趣,简洁而有力的开发语言,用来开发并发/并行程序是一件很愉快的事情.在这里我感受到了其中一 ...

  9. php开发入门教程

    LAMP window:WAMP(windows,apache,mysql,php) LAMP是 Linux,Apache,MySQL和PHP的缩写,是我们提供 Web 服务的软件基础. 对于 Lin ...

  10. 转:jQuery常用插件

    原文来自于:http://download.csdn.net/album/detail/369 jquery.cycle.all.js 上传者:itmyhome      上传时间:2014-06-1 ...