在开发的时候我们可能都需要传一些文件到后台,然后又不希望刷新页面,那么我们可用ajax传文件流到后台。
我们可以在js中用FormData这个对象来包装文件流对象。
1.首先我们怎么能够让file能够选择多个文件呢,很简单加个multiple属性就行,这样就可以再选文件的时候选择多个文件了。
2.接着,我们要在js中获得这个文件对象
技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作
$("#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 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属性,把他的值改大一点就可以了。









