spring 上传文件

提示:本文是在 spring mvc 入门(包括返回结果为json的请求处理)基础上讨论的。

一、XML配置

在abc-servlet.xml上添加

    <!-- MultipartResolver for parsing file uploads, implementation for Commons FileUpload ,
    	needs commons-fileupload.jar,commons-io.jar -->
	<!-- 以字节为单位的最大上传文件的大小 2M -->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
		<property name="resolveLazily" value="true"/>
		<property name="maxUploadSize" value="2097152"/>
		<property name="maxInMemorySize" value="4096" />
		<property name="defaultEncoding" value="UTF-8" />
	</bean>

二、处理类

@Controller
@RequestMapping(value="uploadAndDown")
public class UploadAndDownController extends BaseController {
	
	@RequestMapping(value="upload",method=RequestMethod.POST)
	public String handleUpload(HttpServletRequest request,HttpServletResponse response){
		MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
		CommonsMultipartFile cmFile = (CommonsMultipartFile)multipartRequest.getFile("firstFile");
		PrintWriter out = null;
		if(!cmFile.isEmpty()){
			try {
				File uploadFile = new File("d:"+File.separator+"temp"+File.separator+"1.jpg");
				if(uploadFile.isDirectory())
					uploadFile.delete();
				if(!uploadFile.exists())
					uploadFile.createNewFile();
				cmFile.getFileItem().write(uploadFile);
				
				responseSetting(response);
				out = response.getWriter();
				out.write("<script>parent.uploadCallback('上传成功。');</script>");
			} catch (Exception e) {
				log.error(e);
			} finally {
				if(out != null)
					out.close();
			}
		}else{
			log.error("file name " + cmFile.getName()+ " uploaded is empty.");
		}
		return null;
	}
	
	@ExceptionHandler(MaxUploadSizeExceededException.class)
	public String handleMaxUploadSizeExceededException(MaxUploadSizeExceededException ex, 
			HttpServletRequest request,HttpServletResponse response){
		PrintWriter out = null;
		try {
			responseSetting(response);
			out = response.getWriter();
			out.write("<script>parent.uploadCallback('上传文件太大。');</script>");
		} catch (IOException e) {
			log.error(e,e);
		} finally {
			if(out != null)
				out.close();
		}
		return null;
	}

三、发起上传文件的界面

<div style="margin: 50px 0 0 0">
	<form id="uploadForm" action="" enctype="" target="">
		<input type="file" id="firstFile" name="firstFile"/>
		<input type="submit" value="Submit" οnclick="upload()"/>
	</form>
</div>
<iframe id="uploadAndDownFrame" name="uploadAndDownFrame" style="display: none;"></iframe>

其中处理的javascript:

function upload(){
	$("#uploadForm").attr("target","uploadAndDownFrame");
	$("#uploadForm").attr("enctype","multipart/form-data");	
	$("#uploadForm").attr("method","POST");
	$("#uploadForm").attr("action","${path}/rest/uploadAndDown/upload");
	$("#uploadForm").submit();
}
function uploadCallback(re){
	alert(re);
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值