首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Java Web开发 >

jsp 兑现本地文件夹目录遍历并上传此目录下的文件

2013-04-27 
jsp 实现本地文件夹目录遍历并上传此目录下的文件希望用户能够通过自己的浏览器选择一个本地的文件夹目录,

jsp 实现本地文件夹目录遍历并上传此目录下的文件
    希望用户能够通过自己的浏览器选择一个本地的文件夹目录,并将此目录下的所有文件上传到服务器中。如果是单个文件用file控件很好实现,如果需要遍历本地文件夹目录并上传该如何实现呢。
    我在网上找到了一个相关的例子,是利用ActiveX来做的,但似乎不完全,后台java程序中继承的Action类没有交代。
    这方面资料太少,急用,还望大神指点!
下面是找的这个例子:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>UpLoad</title>
<script type="text/javascript" >
function fileupload(filepath){  
if(filepath!=""){    
sendFileToServer(filepath);  
}  else{  
alert("请选择要上传的文件");  

}
function callback() {   
if (xmlhttp.readyState == 4) {       
var responseText = xmlhttp.responseText;          
}
}
function sendByteStreamToServer(stream,url){  
if (window.XMLHttpRequest) {      
xmlhttp = new XMLHttpRequest();       
if (xmlhttp.overrideMimeType) {          
xmlhttp.overrideMimeType("text/xml")      
}  
} else if (window.ActiveXObject) {       
var activexName = ["MSXML2.XMLHTTP","Microsoft.XMLHTTP"];      
for (var i = 0; i < activexName.length; i++) {          
try {              
xmlhttp = new ActiveXObject(activexName[i]);              
break;          
} catch(e) {               
e.print()          
}    


xmlhttp.onreadystatechange = callback;  
xmlhttp.open("post", url, false);  
boundary="abcd"  
xmlhttp.setRequestHeader("Content-Type", "multipart/form-data, boundary="+boundary);
xmlhttp.setRequestHeader("Content-Length", stream.Size); 
xmlhttp.send(stream); 
}
function sendFileToServer(filePath){     
var filepath=encodeURI(encodeURI(filePath));    
var stream =new ActiveXObject("ADODB.Stream");     
stream.Type=1;     
stream.Open();     
stream.Position = 0;//指定或返加对像内数据的当前指针。
stream.LoadFromFile(filePath) //将FileName指定的文件装入对像中,参数FileName为指定的用户名
stream.Position = 0;
sendByteStreamToServer(stream,"<%=request.getContextPath() %>/upLoad.do?path="+filepath);//请求路径
stream.Close();
}
var countfiles=0;
var countfolders=0;
//用于打开浏览对话框选择路径
function BrowseFolder(){
try{   
var Message = "请选择文件夹"; //选择框提示信息
var Shell = new ActiveXObject( "Shell.Application" );   


var Folder = Shell.BrowseForFolder(0,Message,0x0040,0x11);//起始目录为我的电脑
//var Folder = Shell.BrowseForFolder(0,Message,0); //起始目录为桌面
 if(Folder != null){
Folder = Folder.items(); // 返回 FolderItems 对象 
Folder = Folder.item(); // 返回 Folderitem 对象
Folder = Folder.Path; // 返回路径
if(Folder.charAt(Folder.length-1) != "\"){
Folder = Folder + "\";   
}
return Folder;
}else{      
Folder=""; 
return Folder;  

} catch(e){     
alert(e.message+"11"); 
}
}
//用于遍历
function traverse(localPath,textHtml){ 
var fso = new ActiveXObject("Scripting.FileSystemObject"); 
var currentFolder = fso.GetFolder(localPath);   
var fileList = new Enumerator(currentFolder.files);   
var subFolderList = "";   
var fileHtml=textHtml;   
var aFile;      
for (; !fileList.atEnd(); fileList.moveNext()) { 
countfiles++;   
aFile=fileList.item();
fileHtml.push(aFile.Path);
}
subFolderList = new Enumerator(currentFolder.SubFolders); 
for (; !subFolderList.atEnd(); subFolderList.moveNext())   { 
countfolders++;
 fileHtml=traverse(subFolderList.item().Path,fileHtml)//递归遍历子文件夹  
}
return(fileHtml);
}
function showDiv(){
document.getElementById('loadStyle').style.display='inline';
}
function browse(){
showDiv(); 
document.all.path.value=BrowseFolder();
if(viewfiles()){
document.getElementById('loadStyle').style.display='none';
alert("文件上传成功");
}//上传文件
}

function viewfiles(){
var ts = document.getElementById('loadStyle');
var flag = true;
var textHtml = new Array(); 
var textHtmls = new Array(); 
var folderpath=document.all.path.value;
if(folderpath == ''){
document.getElementById('loadStyle').style.display='none';
flag = false;
}else{
setTimeout("showDiv()",2000);
textHtmls=traverse(folderpath,textHtml);
for(var i=0;i<(textHtmls.length);i++){    
fileupload(textHtmls[i]);
ts.innerHTML = textHtmls[i] + "<br/>";
}  
flag = true;
}
return flag;
}
 </script>


</head>
<body>
<input type="text" id="path" name="path">
<input type="button" value="选择" onclick="browse()">
<div style="display: none;" id="loadStyle">
文件上传中
</div>
</body>
</html>





后台java脚本如下:




public class Upload extends Action {


@Override
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
response.setContentType("text/plain");
PrintWriter outNet = response.getWriter(); 

int id = Integer.parseInt(request.getParameter("id"));
String filePath = java.net.URLDecoder.decode(request.getParameter("path"),"UTF-8");


String fileName = filePath.substring(filePath.lastIndexOf("\") +1);
String loadPath = "E:\\demo\\test\";    //将要上传到的路径。
InputStream in = request.getInputStream();
BufferedInputStream bis = new BufferedInputStream(in);
File file = new File(loadPath);
if(!file.exists()){
file.mkdir();
}
BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(new File(loadPath + fileName)));
int b = 0;
while((b = bis.read()) != -1){
bos.write(b);
bos.flush();
}
bis.close();
bos.close();
in.close();
System.out.println("文件上传成功");
return null;
}

[解决办法]
你要做个浏览器插件啊
[解决办法]
可以通过开发一个ocx控件来选择文件夹
[解决办法]
ocx相当于一个exe文件,需要ie设置允许ocx插件运行
[解决办法]
遍历文件

js上传文件

两个结合起来上传就可以了。

热点排行