文件操作工具类
Posted weigy
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了文件操作工具类相关的知识,希望对你有一定的参考价值。
FileUploadUtil
package com.gootrip.util; import java.io.File; import java.util.*; import org.apache.commons.fileupload.*; import javax.servlet.http.HttpServletRequest; import java.util.regex.Pattern; import java.io.IOException; import org.apache.commons.fileupload.servlet.ServletFileUpload; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import java.util.regex.Matcher; /** * @author * * TODO 要更改此生成的类型注释的模板,请转至 * 窗口 - 首选项 - Java - 代码样式 - 代码模板 */ public class FileUploadUtil { //当上传文件超过限制时设定的临时文件位置,注意是绝对路径 private String tempPath = null; //文件上传目标目录,注意是绝对路径 private String dstPath = null; //新文件名称,不设置时默认为原文件名 private String newFileName = null; //获取的上传请求 private HttpServletRequest fileuploadReq = null; //设置最多只允许在内存中存储的数据,单位:字节,这个参数不要设置太大 private int sizeThreshold = 4096; //设置允许用户上传文件大小,单位:字节 //共10M private long sizeMax = 10485760; //图片文件序号 private int picSeqNo = 1; private boolean isSmallPic = false; public FileUploadUtil(){ } public FileUploadUtil(String tempPath, String destinationPath){ this.tempPath = tempPath; this.dstPath = destinationPath; } public FileUploadUtil(String tempPath, String destinationPath, HttpServletRequest fileuploadRequest){ this.tempPath = tempPath; this.dstPath = destinationPath; this.fileuploadReq = fileuploadRequest; } /** 文件上载 * @return true —— success; false —— fail. */ public boolean Upload(){ DiskFileItemFactory factory = new DiskFileItemFactory(); try { //如果没有上传目的目录,则创建它 FileUtil.makeDirectory(dstPath+"/ddd"); /*if (!FileUtil.makeDirectory(dstPath+"/ddd")) { throw new IOException("Create destination Directory Error."); }*/ //如果没有临时目录,则创建它 FileUtil.makeDirectory(tempPath+"/ddd"); /*if (!FileUtil.makeDirectory(tempPath+"/ddd")) { throw new IOException("Create Temp Directory Error."); }*/ //上传项目只要足够小,就应该保留在内存里。 //较大的项目应该被写在硬盘的临时文件上。 //非常大的上传请求应该避免。 //限制项目在内存中所占的空间,限制最大的上传请求,并且设定临时文件的位置。 //设置最多只允许在内存中存储的数据,单位:字节 factory.setSizeThreshold(sizeThreshold); // the location for saving data that is larger than getSizeThreshold() factory.setRepository(new File(tempPath)); ServletFileUpload upload = new ServletFileUpload(factory); //设置允许用户上传文件大小,单位:字节 upload.setSizeMax(sizeMax); List fileItems = upload.parseRequest(fileuploadReq); // assume we know there are two files. The first file is a small // text file, the second is unknown and is written to a file on // the server Iterator iter = fileItems.iterator(); // 正则匹配,过滤路径取文件名 String regExp = ".+\\(.+)$"; // 过滤掉的文件类型 String[] errorType = {".exe", ".com", ".cgi", ".asp", ".php", ".jsp"}; Pattern p = Pattern.compile(regExp); while (iter.hasNext()) { System.out.println("++00++====="+newFileName); FileItem item = (FileItem) iter.next(); //忽略其他不是文件域的所有表单信息 if (!item.isFormField()) { String name = item.getName(); System.out.println("++++====="+name); long size = item.getSize(); //有多个文件域时,只上传有文件的 if ((name == null || name.equals("")) && size == 0) continue; Matcher m = p.matcher(name); boolean result = m.find(); if (result) { for (int temp = 0; temp < errorType.length; temp++) { if (m.group(1).endsWith(errorType[temp])) { throw new IOException(name + ": Wrong File Type"); } } String ext = "."+FileUtil.getTypePart(name); try { //保存上传的文件到指定的目录 //在下文中上传文件至数据库时,将对这里改写 //没有指定新文件名时以原文件名来命名 if (newFileName == null || newFileName.trim().equals("")) { item.write(new File(dstPath +"/"+ m.group(1))); } else { String uploadfilename = ""; if (isSmallPic) { uploadfilename = dstPath +"/"+ newFileName+"_"+picSeqNo+"_small"+ext; } else { uploadfilename = dstPath +"/"+ newFileName+"_"+picSeqNo+ext; } //生成所有未生成的目录 System.out.println("++++====="+uploadfilename); FileUtil.makeDirectory(uploadfilename); //item.write(new File(dstPath +"/"+ newFileName)); item.write(new File(uploadfilename)); } picSeqNo++; //out.print(name + " " + size + "<br>"); } catch (Exception e) { //out.println(e); throw new IOException(e.getMessage()); } } else { throw new IOException("fail to upload"); } } } } catch (IOException e) { System.out.println(e); } catch (FileUploadException e) { System.out.println(e); } return true; } /**从路径中获取单独文件名 * @author * * TODO 要更改此生成的类型注释的模板,请转至 * 窗口 - 首选项 - Java - 代码样式 - 代码模板 */ public String GetFileName(String filepath) { String returnstr = "*.*"; int length = filepath.trim().length(); filepath = filepath.replace(‘\‘, ‘/‘); if(length >0) { int i = filepath.lastIndexOf("/"); if (i >= 0) { filepath = filepath.substring(i + 1); returnstr = filepath; } } return returnstr; } /** * 设置临时存贮目录 */ public void setTmpPath(String tmppath) { this.tempPath = tmppath; } /** * 设置目标目录 */ public void setDstPath(String dstpath) { this.dstPath = dstpath; } /** * 设置最大上传文件字节数,不设置时默认10M */ public void setFileMaxSize(long maxsize) { this.sizeMax = maxsize; } /** * 设置Http 请求参数,通过这个能数来获取文件信息 */ public void setHttpReq(HttpServletRequest httpreq) { this.fileuploadReq = httpreq; } /** * 设置Http 请求参数,通过这个能数来获取文件信息 */ public void setNewFileName(String filename) { this.newFileName = filename; } /** * 设置此上传文件是否是缩略图文件,这个参数主要用于缩略图命名 */ public void setIsSmalPic(boolean isSmallPic) { this.isSmallPic = isSmallPic; } /** * 设置Http 请求参数,通过这个能数来获取文件信息 */ public void setPicSeqNo(int seqNo) { this.picSeqNo = seqNo; } }
FileUtil
package com.gootrip.util; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.FileReader; import java.io.FileWriter; import java.io.FilenameFilter; import java.io.IOException; import java.net.MalformedURLException; import java.net.URL; import java.util.ArrayList; import java.util.Enumeration; import java.util.Hashtable; import javax.swing.filechooser.FileFilter; /** * 此类中封装一些常用的文件操作。 * 所有方法都是静态方法,不需要生成此类的实例, * 为避免生成此类的实例,构造方法被申明为private类型的。 * @since 1.0 */ public class FileUtil { /** * 私有构造方法,防止类的实例化,因为工具类不需要实例化。 */ private FileUtil() { } /** * 修改文件的最后访问时间。 * 如果文件不存在则创建该文件。 * <b>目前这个方法的行为方式还不稳定,主要是方法有些信息输出,这些信息输出是否保留还在考虑中。</b> * @param file 需要修改最后访问时间的文件。 * @since 1.0 */ public static void touch(File file) { long currentTime = System.currentTimeMillis(); if (!file.exists()) { System.err.println("file not found:" + file.getName()); System.err.println("Create a new file:" + file.getName()); try { if (file.createNewFile()) { System.out.println("Succeeded!"); } else { System.err.println("Create file failed!"); } } catch (IOException e) { System.err.println("Create file failed!"); e.printStackTrace(); } } boolean result = file.setLastModified(currentTime); if (!result) { System.err.println("touch failed: " + file.getName()); } } /** * 修改文件的最后访问时间。 * 如果文件不存在则创建该文件。 * <b>目前这个方法的行为方式还不稳定,主要是方法有些信息输出,这些信息输出是否保留还在考虑中。</b> * @param fileName 需要修改最后访问时间的文件的文件名。 * @since 1.0 */ public static void touch(String fileName) { File file = new File(fileName); touch(file); } /** * 修改文件的最后访问时间。 * 如果文件不存在则创建该文件。 * <b>目前这个方法的行为方式还不稳定,主要是方法有些信息输出,这些信息输出是否保留还在考虑中。</b> * @param files 需要修改最后访问时间的文件数组。 * @since 1.0 */ public static void touch(File[] files) { for (int i = 0; i < files.length; i++) { touch(files[i]); } } /** * 修改文件的最后访问时间。 * 如果文件不存在则创建该文件。 * <b>目前这个方法的行为方式还不稳定,主要是方法有些信息输出,这些信息输出是否保留还在考虑中。</b> * @param fileNames 需要修改最后访问时间的文件名数组。 * @since 1.0 */ public static void touch(String[] fileNames) { File[] files = new File[fileNames.length]; for (int i = 0; i < fileNames.length; i++) { files[i] = new File(fileNames[i]); } touch(files); } /** * 判断指定的文件是否存在。 * @param fileName 要判断的文件的文件名 * @return 存在时返回true,否则返回false。 * @since 1.0 */ public static boolean isFileExist(String fileName) { return new File(fileName).isFile(); } /** * 创建指定的目录。 * 如果指定的目录的父目录不存在则创建其目录书上所有需要的父目录。 * <b>注意:可能会在返回false的时候创建部分父目录。</b> * @param file 要创建的目录 * @return 完全创建成功时返回true,否则返回false。 * @since 1.0 */ public static boolean makeDirectory(File file) { File parent = file.getParentFile(); if (parent != null) { return parent.mkdirs(); } return false; } /** * 创建指定的目录。 * 如果指定的目录的父目录不存在则创建其目录书上所有需要的父目录。 * <b>注意:可能会在返回false的时候创建部分父目录。</b> * @param fileName 要创建的目录的目录名 * @return 完全创建成功时返回true,否则返回false。 * @since 1.0 */ public static boolean makeDirectory(String fileName) { File file = new File(fileName); return makeDirectory(file); } /** * 清空指定目录中的文件。 * 这个方法将尽可能删除所有的文件,但是只要有一个文件没有被删除都会返回false。 * 另外这个方法不会迭代删除,即不会删除子目录及其内容。 * @param directory 要清空的目录 * @return 目录下的所有文件都被成功删除时返回true,否则返回false. * @since 1.0 */ public static boolean emptyDirectory(File directory) { boolean result = true; File[] entries = directory.listFiles(); for (int i = 0; i < entries.length; i++) { if (!entries[i].delete()) { result = false; } } return result; } /** * 清空指定目录中的文件。 * 这个方法将尽可能删除所有的文件,但是只要有一个文件没有被删除都会返回false。 * 另外这个方法不会迭代删除,即不会删除子目录及其内容。 * @param directoryName 要清空的目录的目录名 * @return 目录下的所有文件都被成功删除时返回true,否则返回false。 * @since 1.0 */ public static boolean emptyDirectory(String directoryName) { File dir = new File(directoryName); return emptyDirectory(dir); } /** * 删除指定目录及其中的所有内容。 * @param dirName 要删除的目录的目录名 * @return 删除成功时返回true,否则返回false。 * @since 1.0 */ public static boolean deleteDirectory(String dirName) { return deleteDirectory(new File(dirName)); } /** * 删除指定目录及其中的所有内容。 * @param dir 要删除的目录 * @return 删除成功时返回true,否则返回false。 * @since 1.0 */ public static boolean deleteDirectory(File dir) { if ( (dir == null) || !dir.isDirectory()) { throw new IllegalArgumentException("Argument " + dir + " is not a directory. "); } File[] entries = dir.listFiles(); int sz = entries.length; for (int i = 0; i < sz; i++) { if (entries[i].isDirectory()) { if (!deleteDirectory(entries[i])) { return false; } } else { if (!entries[i].delete()) { return false; } } } if (!dir.delete()) { return false; } return true; } /** * 列出目录中的所有内容,包括其子目录中的内容。 * @param fileName 要列出的目录的目录名 * @return 目录内容的文件数组。 * @since 1.0 */ /*public static File[] listAll(String fileName) { return listAll(new File(fileName)); }*/ /** * 列出目录中的所有内容,包括其子目录中的内容。 * @param file 要列出的目录 * @return 目录内容的文件数组。 * @since 1.0 */ /*public static File[] listAll(File file) { ArrayList list = new ArrayList(); File[] files; if (!file.exists() || file.isFile()) { return null; } list(list, file, new AllFileFilter()); list.remove(file); files = new File[list.size()]; list.toArray(files); return files; }*/ /** * 列出目录中的所有内容,包括其子目录中的内容。 * @param file 要列出的目录 * @param filter 过滤器 * @return 目录内容的文件数组。 * @since 1.0 */ public static File[] listAll(File file, javax.swing.filechooser.FileFilter filter) { ArrayList list = new ArrayList(); File[] files; if (!file.exists() || file.isFile()) { return null; } list(list, file, filter); files = new File[list.size()]; list.toArray(files); return files; } /** * 将目录中的内容添加到列表。 * @param list 文件列表 * @param filter 过滤器 * @param file 目录 */ private static void list(ArrayList list, File file, javax.swing.filechooser.FileFilter filter) { if (filter.accept(file)) { list.add(file); if (file.isFile()) { return; } } if (file.isDirectory()) { File files[] = file.listFiles(); for (int i = 0; i < files.length; i++) { list(list, files[i], filter); } } } /** * 返回文件的URL地址。 * @param file 文件 * @return 文件对应的的URL地址 * @throws MalformedURLException * @since 1.0 * @deprecated 在实现的时候没有注意到File类本身带一个toURL方法将文件路径转换为URL。 * 请使用File.toURL方法。 */ public static URL getURL(File file) throws MalformedURLException { String fileURL = "file:/" + file.getAbsolutePath(); URL url = new URL(fileURL); return url; } /** * 从文件路径得到文件名。 * @param filePath 文件的路径,可以是相对路径也可以是绝对路径 * @return 对应的文件名 * @since 1.0 */ public static String getFileName(String filePath) { File file = new File(filePath); return file.getName(); } /** * 从文件名得到文件绝对路径。 * @param fileName 文件名 * @return 对应的文件路径 * @since 1.0 */ public static String getFilePath(String fileName) { File file = new File(fileName); return file.getAbsolutePath(); } /** * 将DOS/Windows格式的路径转换为UNIX/Linux格式的路径。 * 其实就是将路径中的""全部换为"/",因为在某些情况下我们转换为这种方式比较方便, * 某中程度上说"/"比""更适合作为路径分隔符,而且DOS/Windows也将它当作路径分隔符。 * @param filePath 转换前的路径 * @return 转换后的路径 * @since 1.0 */ public static String toUNIXpath(String filePath) { return filePath.replace(‘\‘, ‘/‘); } /** * 从文件名得到UNIX风格的文件绝对路径。 * @param fileName 文件名 * @return 对应的UNIX风格的文件路径 * @since 1.0 * @see #toUNIXpath(String filePath) toUNIXpath */ public static String getUNIXfilePath(String fileName) { File file = new File(fileName); return toUNIXpath(file.getAbsolutePath()); } /** * 得到文件的类型。 * 实际上就是得到文件名中最后一个“.”后面的部分。 * @param fileName 文件名 * @return 文件名中的类型部分 * @since 1.0 */ public static String getTypePart(String fileName) { int point = fileName.lastIndexOf(‘.‘); int length = fileName.length(); if (point == -1 || point == length - 1) { return ""; } else { return fileName.substring(point + 1, length); } } /** * 得到文件的类型。 * 实际上就是得到文件名中最后一个“.”后面的部分。 * @param file 文件 * @return 文件名中的类型部分 * @since 1.0 */ public static String getFileType(File file) { return getTypePart(file.getName()); } /** * 得到文件的名字部分。 * 实际上就是路径中的最后一个路径分隔符后的部分。 * @param fileName 文件名 * @return 文件名中的名字部分 * @since 1.0 */ public static String getNamePart(String fileName) { int point = getPathLsatIndex(fileName); int length = fileName.length(); if (point == -1) { return fileName; } else if (point == length - 1) { int secondPoint = getPathLsatIndex(fileName, point - 1); if (secondPoint == -1) { if (length == 1) { return fileName; } else { return fileName.substring(0, point); } } else { return fileName.substring(secondPoint + 1, point); } } else { return fileName.substring(point + 1); } } /** * 得到文件名中的父路径部分。 * 对两种路径分隔符都有效。 * 不存在时返回""。 * 如果文件名是以路径分隔符结尾的则不考虑该分隔符,例如"/path/"返回""。 * @param fileName 文件名 * @return 父路径,不存在或者已经是父目录时返回"" * @since 1.0 */ public static String getPathPart(String fileName) { int point = getPathLsatIndex(fileName); int length = fileName.length(); if (point == -1) { return ""; } else if (point == length - 1) { int secondPoint = getPathLsatIndex(fileName, point - 1); if (secondPoint == -1) { return ""; } else { return fileName.substring(0, secondPoint); } } else { return fileName.substring(0, point); } } /** * 得到路径分隔符在文件路径中首次出现的位置。 * 对于DOS或者UNIX风格的分隔符都可以。 * @param fileName 文件路径 * @return 路径分隔符在路径中首次出现的位置,没有出现时返回-1。 * @since 1.0 */ public static int getPathIndex(String fileName) { int point = fileName.indexOf(‘/‘); if (point == -1) { point = fileName.indexOf(‘\‘); } return point; } /** * 得到路径分隔符在文件路径中指定位置后首次出现的位置。 * 对于DOS或者UNIX风格的分隔符都可以。 * @param fileName 文件路径 * @param fromIndex 开始查找的位置 * @return 路径分隔符在路径中指定位置后首次出现的位置,没有出现时返回-1。 * @since 1.0 */ public static int getPathIndex(String fileName, int fromIndex) { int point = fileName.indexOf(‘/‘, fromIndex); if (point == -1) { point = fileName.indexOf(‘\‘, fromIndex); } return point; } /** * 得到路径分隔符在文件路径中最后出现的位置。 * 对于DOS或者UNIX风格的分隔符都可以。 * @param fileName 文件路径 * @return 路径分隔符在路径中最后出现的位置,没有出现时返回-1。 * @since 1.0 */ public static int getPathLsatIndex(String fileName) { int point = fileName.lastIndexOf(‘/‘); if (point == -1) { point = fileName.lastIndexOf(‘\‘); } return point; } /** * 得到路径分隔符在文件路径中指定位置前最后出现的位置。 * 对于DOS或者UNIX风格的分隔符都可以。 * @param fileName 文件路径 * @param fromIndex 开始查找的位置 * @return 路径分隔符在路径中指定位置前最后出现的位置,没有出现时返回-1。 * @since 1.0 */ public static int getPathLsatIndex(String fileName, int fromIndex) { int point = fileName.lastIndexOf(‘/‘, fromIndex); if (point == -1) { point = fileName.lastIndexOf(‘\‘, fromIndex); } return point; } /** * 将文件名中的类型部分去掉。 * @param filename 文件名 * @return 去掉类型部分的结果 * @since 1.0 */ public static String trimType(String filename) { int index = filename.lastIndexOf("."); if (index != -1) { return filename.substring(0, index); } else { return filename; } } /** * 得到相对路径。 * 文件名不是目录名的子节点时返回文件名。 * @param pathName 目录名 * @param fileName 文件名 * @return 得到文件名相对于目录名的相对路径,目录下不存在该文件时返回文件名 * @since 1.0 */ public static String getSubpath(String pathName,String fileName) { int index = fileName.indexOf(pathName); if (index != -1) { return fileName.substring(index + pathName.length() + 1); } else { return fileName; } } /** * 检查给定目录的存在性 * 保证指定的路径可用,如果指定的路径不存在,那么建立该路径,可以为多级路径 * @param path * @return 真假值 * @since 1.0 */ public static final boolean pathValidate(String path) { //String path="d:/web/www/sub"; //System.out.println(path); //path = getUNIXfilePath(path); //path = ereg_replace("^\/+", "", path); //path = ereg_replace("\/+$", "", path); String[] arraypath = path.split("/"); String tmppath = ""; for (int i = 0; i < arraypath.length; i++) { tmppath += "/" + arraypath[i]; File d = new File(tmppath.substring(1)); if (!d.exists()) { //检查Sub目录是否存在 System.out.println(tmppath.substring(1)); if (!d.mkdir()) { return false; } } } return true; } /** * 读取文件的内容 * 读取指定文件的内容 * @param path 为要读取文件的绝对路径 * @return 以行读取文件后的内容。 * @since 1.0 */ public static final String getFileContent(String path) throws IOException { String filecontent = ""; try { File f = new File(path); if (f.exists()) { FileReader fr = new FileReader(path); BufferedReader br = new BufferedReader(fr); //建立BufferedReader对象,并实例化为br String line = br.readLine(); //从文件读取一行字符串 //判断读取到的字符串是否不为空 while (line != null) { filecontent += line + " "; line = br.readLine(); //从文件中继续读取一行数据 } br.close(); //关闭BufferedReader对象 fr.close(); //关闭文件 } } catch (IOException e) { throw e; } return filecontent; } /** * 根据内容生成文件 * @param path要生成文件的绝对路径, * @param 文件的内容。 * @return 真假值 * @since 1.0 */ public static final boolean genModuleTpl(String path, String modulecontent) throws IOException { path = getUNIXfilePath(path); String[] patharray = path.split("\/"); String modulepath = ""; for (int i = 0; i < patharray.length - 1; i++) { modulepath += "/" + patharray[i]; } File d = new File(modulepath.substring(1)); if (!d.exists()) { if (!pathValidate(modulepath.substring(1))) { return false; } } try { FileWriter fw = new FileWriter(path); //建立FileWriter对象,并实例化fw //将字符串写入文件 fw.write(modulecontent); fw.close(); } catch (IOException e) { throw e; } return true; } /** * 获取图片文件的扩展名(发布系统专用) * @param picname 为图片名称加上前面的路径不包括扩展名 * @return 图片的扩展名 * @since 1.0 */ public static final String getPicExtendName(String pic_path) { pic_path = getUNIXfilePath(pic_path); String pic_extend = ""; if (isFileExist(pic_path + ".gif")) { pic_extend = ".gif"; } if (isFileExist(pic_path + ".jpeg")) { pic_extend = ".jpeg"; } if (isFileExist(pic_path + ".jpg")) { pic_extend = ".jpg"; } if (isFileExist(pic_path + ".png")) { pic_extend = ".png"; } return pic_extend; //返回图片扩展名 } //拷贝文件 public static final boolean CopyFile(File in, File out) throws Exception { try { FileInputStream fis = new FileInputStream(in); FileOutputStream fos = new FileOutputStream(out); byte[] buf = new byte[1024]; int i = 0; while ((i = fis.read(buf)) != -1) { fos.write(buf, 0, i); } fis.close(); fos.close(); return true; } catch (IOException ie) { ie.printStackTrace(); return false; } } //拷贝文件 public static final boolean CopyFile(String infile, String outfile) throws Exception { try { File in = new File(infile); File out = new File(outfile); return CopyFile(in, out); } catch (IOException ie) { ie.printStackTrace(); return false; } } /** * 计算图片数量 * @param id * @param dtime * @return */ public static final int countPics(String id,String dtime,String extensions){ int counts = 0; MyFileFilter mfilter = new MyFileFilter(extensions.split(",")); PropsUtil pu = new PropsUtil(); String PICROOT = pu.readSingleProps("DestinationsPICROOT").trim(); String path = PICROOT + "/"+dtime.substring(0, 10) + "/"; File lfile = new File(path); String filename; if(lfile.isDirectory()){ File[] files = lfile.listFiles(mfilter); for(int i=0;i<files.length;i++){ filename = files[i].getName(); if((filename.indexOf(id + "_")==0)&&(filename.indexOf("_small")>-1)) counts ++; } files = null; } filename = null; lfile = null; pu = null; mfilter = null; return counts; } }
以上是关于文件操作工具类的主要内容,如果未能解决你的问题,请参考以下文章