ajax+java+传文件_如何在一次ajax内传送一个或多个文件到后台

在开发的时候我们可能都需要传一些文件到后台,然后又不希望刷新页面,那么我们可用ajax传文件流到后台。

我们可以在js中用FormData这个对象来包装文件流对象。

1.首先我们怎么能够让file能够选择多个文件呢,很简单加个multiple属性就行,这样就可以再选文件的时候选择多个文件了。

2.接着,我们要在js中获得这个文件对象$("#submit").click(function() {

var paths = document.getElementById("images").files;

if(paths.length==0)

{

alert("请选择文件");

return;

}

var formData = new FormData();

//alert(paths.length);

//我们遍历每一个文件对象

for (var i = 0; i < paths.length; i++) {

var file = paths[i];

//alert(file.type);

//用正则表达式判断文件的类型是否是图片,这里大家可以自由发挥

if (!new RegExp("image/*").test(file.type)) {

alert("请注意,上传的文件一定要是图片文件");

return;

}

}

//alert("开始上传");

//我们可以预先定义一个FormData对象

var formData=new FormData();

for(var i=0;i

{

//将每个文件设置一个string类型的名字,放入到formData中,这里类似于setAttribute("",Object)

formData.append(paths[i].name,paths[i]);

}

$.ajax({

url: '/MySoleSys/mainServlet',

type: 'POST',

cache: false,

data:formData,

//这个参数是jquery特有的,不进行序列化,因为我们不是json格式的字符串,而是要传文件

processData: false,

//注意这里一定要设置contentType:false,不然会默认为传的是字符串,这样文件就传不过去了

contentType: false,

success:function(returnedData)

{

if($.trim(returnedData)==$.trim("success"))

{

alert("上传图片成功");

window.location.href="/MySoleSys/mainboard/index.html"

}

else if($.trim(returnedData)==$.trim("fail"))

alert("上传图片失败");

}

});

});

3.下一步我们肯定要在后台接收文件啦,这里我已开始用action接受,但总是收不到文件,也许是struts2过滤器的问题,改成用Servlet接受就成了。。。郁闷。。,后台我们用request.getParts()接受FormData.Collectionparts=request.getParts();

Iterator it=parts.iterator();

while(it.hasNext())

{

Part img=it.next();

/**

* 开始传图片到服务器端文件夹。

*/

file=new File(path+"\\"+img.getName());

fos=new FileOutputStream(file);

//可以从每个part中获得文件的输入流,获得输入流之后想怎么搞就怎么搞都可以啦

imgis=img.getInputStream();

int len=-1;

while((len=imgis.read(bytes))!=-1)

{

fos.write(bytes,0, len);

}

fos.flush();

}

还有一点就是如果报一次请求的数据量太大了的话,可以在struts.xml配置struts.multipart.maxSize属性,把他的值改大一点就可以了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值