文件夹上传(JavaScript及Java)

平时经常做的是上传文件,上传文件夹与上传文件类似,但也有一些不同之处,这次做了上传文件夹就记录下以备后用。

首先我们需要了解的是上传文件三要素:

1.表单提交方式:post (get方式提交有大小限制,post没有)

2.表单的enctype属性:必须设置为multipart/form-data. 

3.表单必须有文件上传项:file,且文件项需要给定name值

上传文件夹需要增加一个属性webkitdirectory,像这样:

<input id="fileFolder" name="fileFolder" type="file"  webkitdirectory>


js中可以判断文件夹中文件数量及文件夹大小是否符合要求,不符合要求不能向后台提交:

document.getElementById('fileFolder').onchange = function(e) {
actual_filesSize=0;
//是否选中文件夹  文件夹是否为空  数量和大小是否超过限制
//判断是否选中文件
  var file=$("#fileFolder").val();
  if(file!=""){
  var files = e.target.files;            // files是选中的文件夹数组
  //文件数量
  actual_filesCount = files.length;
  if(actual_filesCount > filesCount){
  $("#tips").text(msg2+filesCount+msg3);
  document.getElementById("tips").style.color="red";
  return;
  }
  //修改tips文本框内容
  $("#tips").text(actual_filesCount+tip);
  document.getElementById("tips").style.color="black";
  
  for (var i = 0; i< files.length; ++i){
  actual_filesSize=actual_filesSize+files[i].size;
  if(actual_filesSize > filesSize){
  $("#tips").text(msg4+(filesSize/1024/1024)+"M");
  document.getElementById("tips").style.color="red";
  return;
  }
  }
  }else{
  $("#tips").text(msg);
  document.getElementById("tips").style.color="red";
  return;
  }
  };


后台在接收文件夹时不同之处在需要用MultipartHttpServletRequest

@RequestMapping(value="/sys/uploadFolder",method=RequestMethod.POST)
@ResponseBody
public String uploadFileFolder(HttpServletRequest request) {

        MultipartHttpServletRequest params=((MultipartHttpServletRequest) request); 
        List<MultipartFile> files = params.getFiles("fileFolder");     //fileFolder为文件项的name值
        String result = sysFilesUploadService.upload(files);
        return "<h1>" + result + "</h1>";


    }


以下是service层做的处理:

@Service("sysFilesUploadService")
public class SysFilesUploadServiceImpl implements SysFilesUploadService {

//文件存储地址
@Value("${file_storage_address}")
private String Storage_PATH;
@Value("${file_format_require}")
private String File_Format;

@Override
public String upload(List<MultipartFile> files) {

BufferedOutputStream bos =null;
     BufferedInputStream bis=null;
     
     //文件格式要求
     String[] suffixArr = File_Format.split(",");
     List<String> suffixList = Arrays.asList(suffixArr);
     
     //判断存储的文件夹是否存在
     File file=new File(Storage_PATH);
     if(!file.exists()) {
    file.mkdirs(); 
     }
     
        try {
//遍历文件夹
        for (MultipartFile mf : files) {
if(!mf.isEmpty()) {
String originalFilename = mf.getOriginalFilename();
String  suffix = originalFilename.substring(originalFilename.lastIndexOf(".")+1);
//格式限制,非wav格式的不上传
if(!suffixList.contains(suffix)) {
continue;
}
String fileName=originalFilename.substring(originalFilename.lastIndexOf("/")+1);
//为避免文件同名覆盖,给文件名加上时间戳
int index = fileName.lastIndexOf(".");
String firstName=fileName.substring(0, index);
String lastName=fileName.substring(index);
fileName=firstName+"_"+System.currentTimeMillis()+lastName;
//读取文件
bis=new BufferedInputStream (mf.getInputStream());
//指定存储的路径
bos=new BufferedOutputStream(new FileOutputStream
(Storage_PATH+fileName));
int len=0;
byte[] buffer=new byte[10240];
            while((len=bis.read(buffer))!=-1){
                bos.write(buffer, 0, len);
            }
            //刷新此缓冲的输出流,保证数据全部都能写出
            bos.flush();
}
}
        if(bis!=null) {
        bis.close();
        }
        if(bos!=null) {
        bos.close();
        }
        return "ok";
} catch (FileNotFoundException e) {      
        e.printStackTrace();      
        return "error";      
    } catch (IOException e) {      
        e.printStackTrace();      
        return "error";          
    }
}


}

  • 2
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Java文件夹复制(远程复制(网络传输),用于远程备份文件)(支持文件夹,嵌套子文件夹) import java.io.*; import java.util.*; public class FileSelection { private File rootDirectory;//根目录 private File[] fileList;//文件目录下面的文件列表(包括目录,用于多次判断) private ArrayList fileArrayList; // 用于存储文件(只是文件)列表 //初始化参数 public FileSelection() { fileArrayList=new ArrayList(); rootDirectory = new File("Test"); rootDirectory.mkdir(); } //获得文件(不包括目录)的列表 public void initFileArrayList() { if (rootDirectory.isDirectory()) { //遍历目录下面的文件和子目录 fileList = rootDirectory.listFiles(); for (int i = 0; i < fileList.length; i++) { //如果是文件,添加到文件列表中 if(fileList[i].isFile()){ fileArrayList.add(fileList[i]); } //否则递归遍历子目录 else if (fileList[i].isDirectory()) { fileList[i].mkdir(); rootDirectory=fileList[i]; initFileArrayList(); } } } } //将文件信息添加到列表中 public void addFiles(File f){ fileArrayList.add(f); } //访问器返回文件列表 public ArrayList getFileArrayList() { return fileArrayList; } } -------------------- BackupClient.java package com.xinxin.Client; import java.io.*; import java.net.*; /** * * @author Administrator *@version 1.0 *BackupClient类实现文件的传输到服务器 */ public class BackupClient implements Runnable{ private int port;//服务器端口 private InetAddress ipAddress;//服务器IP地址 private Socket clientSocket;//客户端套接字 private InputStream inputStream;//网络输入流 private OutputStream outputStream;//网络输出流 private File file; //构造函数(获得服务器端IP地址和监听端口号) public BackupClient(InetAddress ipAddress,int port,File file){ this.ipAddress=ipAddress; this.port=port;
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值