我们可以在js中用formdata这个对象来包装文件流对象。
1.首先我们怎么能够让file能够选择多个文件呢,很简单加个multiple属性就行,这样就可以再选文件的时候选择多个文件了。
<input type="file" id="images" name="images" 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<paths.length;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.
collection<part>parts=request.getparts(); iterator<part> 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属性,把他的值改大一点就可以了。
<constant name="struts.multipart.maxsize" value="9000000" />