【转】java路径详解
2010-08-03 16:48 136人阅读 评论(1) 收藏 举报
- 1.如何获得当前文件路径
- 常用:
- (1).Test.class.getResource("")
- 得到的是当前类FileTest.class文件的URI目录。不包括自己!
- (2).Test.class.getResource("/")
- 得到的是当前的classpath的绝对URI路径。
- (3).Thread.currentThread().getContextClassLoader().getResource("")
- 得到的也是当前ClassPath的绝对URI路径。
- (4).Test.class.getClassLoader().getResource("")
- 得到的也是当前ClassPath的绝对URI路径。
- (5).ClassLoader.getSystemResource("")
- 得到的也是当前ClassPath的绝对URI路径。
- 尽量不要使用相对于System.getProperty("user.dir")当前用户目录的相对路径,后面可以看出得出结
- 果五花八门。
- (6) new File("").getAbsolutePath()也可用。
- 2.Web服务器
- (1).Tomcat
- 在类中输出System.getProperty("user.dir");显示的是%Tomcat_Home%/bin
- (2).Resin
- 不是你的JSP放的相对路径,是JSP引擎执行这个JSP编译成SERVLET
- 的路径为根.比如用新建文件法测试File f = new File("a.htm");
- 这个a.htm在resin的安装目录下
- (3).如何读文件
- 使用ServletContext.getResourceAsStream()就可以
- (4).获得文件真实路径
- String file_real_path=ServletContext.getRealPath("mypath/filename");
- 不建议使用request.getRealPath("/");
- 3.文件操作的类,不建议使用,可以使用commons io类
- import java.io.*;
- import java.net.*;
- import java.util.*;
- /**
- * 此类中封装一些常用的文件操作。
- * 所有方法都是静态方法,不需要生成此类的实例,
- * 为避免生成此类的实例,构造方法被申明为private类型的。
- * @since 0.1
- */
- public class FileUtil {
- /**
- * 私有构造方法,防止类的实例化,因为工具类不需要实例化。
- */
- private FileUtil() {
- }
- /**
- * 修改文件的最后访问时间。
- * 如果文件不存在则创建该文件。
- * <b>目前这个方法的行为方式还不稳定,主要是方法有些信息输出,这些信息输出是否保留还在考
- 虑中。</b>
- * @param file 需要修改最后访问时间的文件。
- * @since 0.1
- */
- 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 0.1
- */
- public static void touch(String fileName) {
- File file = new File(fileName);
- touch(file);
- }
- /**
- * 修改文件的最后访问时间。
- * 如果文件不存在则创建该文件。
- * <b>目前这个方法的行为方式还不稳定,主要是方法有些信息输出,这些信息输出是否保留还在考
- 虑中。</b>
- * @param files 需要修改最后访问时间的文件数组。
- * @since 0.1
- */
- public static void touch(File[] files) {
- for (int i = 0; i < files.length; i++) {
- touch(files);
- }
- }
- /**
- * 修改文件的最后访问时间。
- * 如果文件不存在则创建该文件。
- * <b>目前这个方法的行为方式还不稳定,主要是方法有些信息输出,这些信息输出是否保留还在考
- 虑中。</b>
- * @param fileNames 需要修改最后访问时间的文件名数组。
- * @since 0.1
- */
- public static void touch(String[] fileNames) {
- File[] files = new File[fileNames.length];
- for (int i = 0; i < fileNames.length; i++) {
- files = new File(fileNames);
- }
- touch(files);
- }
- /**
- * 判断指定的文件是否存在。
- * @param fileName 要判断的文件的文件名
- * @return 存在时返回true,否则返回false。
- * @since 0.1
- */
- public static boolean isFileExist(String fileName) {
- return new File(fileName).isFile();
- }
- /**
- * 创建指定的目录。
- * 如果指定的目录的父目录不存在则创建其目录书上所有需要的父目录。
- * <b>注意:可能会在返回false的时候创建部分父目录。</b>
- * @param file 要创建的目录
- * @return 完全创建成功时返回true,否则返回false。
- * @since 0.1
- */
- 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 0.1
- */
- public static boolean makeDirectory(String fileName) {
- File file = new File(fileName);
- return makeDirectory(file);
- }
- /**
- * 清空指定目录中的文件。
- * 这个方法将尽可能删除所有的文件,但是只要有一个文件没有被删除都会返回false。
- * 另外这个方法不会迭代删除,即不会删除子目录及其内容。
- * @param directory 要清空的目录
- * @return 目录下的所有文件都被成功删除时返回true,否则返回false.
- * @since 0.1
- */
- public static boolean emptyDirectory(File directory) {
- boolean result = false;
- File[] entries = directory.listFiles();
- for (int i = 0; i < entries.length; i++) {
- if (!entries.delete()) {
- result = false;
- }
- }
- return true;
- }
- /**
- * 清空指定目录中的文件。
- * 这个方法将尽可能删除所有的文件,但是只要有一个文件没有被删除都会返回false。
- * 另外这个方法不会迭代删除,即不会删除子目录及其内容。
- * @param directoryName 要清空的目录的目录名
- * @return 目录下的所有文件都被成功删除时返回true,否则返回false。
- * @since 0.1
- */
- public static boolean emptyDirectory(String directoryName) {
- File dir = new File(directoryName);
- return emptyDirectory(dir);
- }
- /**
- * 删除指定目录及其中的所有内容。
- * @param dirName 要删除的目录的目录名
- * @return 删除成功时返回true,否则返回false。
- * @since 0.1
- */
- public static boolean deleteDirectory(String dirName) {
- return deleteDirectory(new File(dirName));
- }
- /**
- * 删除指定目录及其中的所有内容。
- * @param dir 要删除的目录
- * @return 删除成功时返回true,否则返回false。
- * @since 0.1
- */
- 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.isDirectory()) {
- if (!deleteDirectory(entries)) {
- return false;
- }
- }
- else {
- if (!entries.delete()) {
- return false;
- }
- }
- }
- if (!dir.delete()) {
- return false;
- }
- return true;
- }
- /**
- * 返回文件的URL地址。
- * @param file 文件
- * @return 文件对应的的URL地址
- * @throws MalformedURLException
- * @since 0.4
- * @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 0.4
- */
- public static String getFileName(String filePath) {
- File file = new File(filePath);
- return file.getName();
- }
- /**
- * 从文件名得到文件绝对路径。
- * @param fileName 文件名
- * @return 对应的文件路径
- * @since 0.4
- */
- public static String getFilePath(String fileName) {
- File file = new File(fileName);
- return file.getAbsolutePath();
- }
- /**
- * 将DOS/Windows格式的路径转换为UNIX/Linux格式的路径。
- * 其实就是将路径中的"/"全部换为"/",因为在某些情况下我们转换为这种方式比较方便,
- * 某中程度上说"/"比"/"更适合作为路径分隔符,而且DOS/Windows也将它当作路径分隔符。
- * @param filePath 转换前的路径
- * @return 转换后的路径
- * @since 0.4
- */
- public static String toUNIXpath(String filePath) {
- return filePath.replace('//', '/');
- }
- /**
- * 从文件名得到UNIX风格的文件绝对路径。
- * @param fileName 文件名
- * @return 对应的UNIX风格的文件路径
- * @since 0.4
- * @see #toUNIXpath(String filePath) toUNIXpath
- */
- public static String getUNIXfilePath(String fileName) {
- File file = new File(fileName);
- return toUNIXpath(file.getAbsolutePath());
- }
- /**
- * 得到文件的类型。
- * 实际上就是得到文件名中最后一个“.”后面的部分。
- * @param fileName 文件名
- * @return 文件名中的类型部分
- * @since 0.5
- */
- 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 0.5
- */
- public static String getFileType(File file) {
- return getTypePart(file.getName());
- }
- /**
- * 得到文件的名字部分。
- * 实际上就是路径中的最后一个路径分隔符后的部分。
- * @param fileName 文件名
- * @return 文件名中的名字部分
- * @since 0.5
- */
- 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 0.5
- */
- 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 0.5
- */
- 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 0.5
- */
- 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 0.5
- */
- 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 0.5
- */
- 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 0.5
- */
- 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 0.5
- */
- 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;
- }
- }
- }
- 4.遗留问题
- 目前new FileInputStream()只会使用绝对路径,相对没用过,因为要相对于web服务器地址,比较麻烦
- 还不如写个配置文件来的快哪
- 5.按Java文件类型分类读取配置文件
- 配 置文件是应用系统中不可缺少的,可以增加程序的灵活性。java.util.Properties是从jdk1.2就有
- 的类,一直到现在都支持load ()方法,jdk1.4以后save(output,string) ->store(output,string)。
- 如果只是单纯的读,根本不存在烦恼的问题。web层可以通过 Thread.currentThread
- ().getContextClassLoader().
- getResourceAsStream("xx.properties") 获取;Application可以通过new FileInputStream
- ("xx.properties");直接在classes一级获取。关键是有时我们需要通过web修改配置文件,我们不 能
- 将路径写死了。经过测试觉得有以下心得:
- 1.servlet中读写。如果运用Struts 或者Servlet可以直接在初始化参数中配置,调用时根据
- servletcontext的getRealPath("/")获取真实路径,再根据String file =
- this.servlet.getInitParameter("abc");获取相对的WEB-INF的相对路径。
- 例:
- InputStream input = Thread.currentThread().getContextClassLoader().
- getResourceAsStream("abc.properties");
- Properties prop = new Properties();
- prop.load(input);
- input.close();
- OutputStream out = new FileOutputStream(path);
- prop.setProperty("abc", “test");
- prop.store(out, “–test–");
- out.close();
- 2.直接在jsp中操作,通过jsp内置对象获取可操作的绝对地址。
- 例:
- // jsp页面
- String path = pageContext.getServletContext().getRealPath("/");
- String realPath = path+"/WEB-INF/classes/abc.properties";
- //java 程序
- InputStream in = getClass().getClassLoader().getResourceAsStream("abc.properties"); //
- abc.properties放在webroot/WEB-INF/classes/目录下
- prop.load(in);
- in.close();
- OutputStream out = new FileOutputStream(path); // path为通过页面传入的路径
- prop.setProperty("abc", “abcccccc");
- prop.store(out, “–test–");
- out.close();
- 3.只通过Java程序操作资源文件
- InputStream in = new FileInputStream("abc.properties"); // 放在classes同级
- OutputStream out = new FileOutputStream("abc.properties");
关于绝对路径和相对路径: |
java路径问题
- 在很多地方都碰到了JAVA中的路径问题,总结起来有以下几点:
- 1、使用绝对路径的时候,应该使用“D://temp//”或者"D:/temp/"等形式.
- 2、如果我们是在eclipse下面运行一个Java类,那么它的当前路径应该是工程目录下,和bin文件夹同级别。
- 3、如果我们是在tomcat下面运行,那么它的当前路径应该就是bin目录。因为这里是整个程序运行的入口。比如File a=new File("frid.jpg");那么这个文件应该就在bin目录下的frid.jpg.
- 4、很多时候在tomcat的项目工程中获得一个相对路径,比如在创建Javabean和java类或者servlet的时候需要在当前index.jsp所在的目录下建立一个文件夹temp,该怎么做呢?我们可以使用如下方法:
- //假设当前类为PicStatic,包为com.dc.most.那么以下语句则是返回该类所在的目录,注意:返回的变量a 中的空格会自动用%20替换,因此需要对它进行处理,否则java无法辨认该路径.
- String a=com.dc.most.PicStatic.class.getResource("").toString();
- a=a.replaceAll("%20", " ");
- //通过以下两句取得JSP文件所在目录
- String b=new String("WEB-INF/classes/com/dc/most/");
- a=a.substring(0,a.lastIndexOf("/", a.length()-(b.length())));
- //去掉file:/,否则无法辨认
- a=a.substring(a.indexOf("/")+1);
- //如果该目录不存在,则创建
- File myFilePath = new File(a+"/temp/");
- if (!myFilePath.exists()) {
- myFilePath.mkdir();
- }
- //创建文件流
- fos_jpg = new FileOutputStream(myFilePath +"/"+ filename);
- if (extname.equalsIgnoreCase("jpg"))
- ChartUtilities.writeChartAsJPEG(fos_jpg, 100, chart, width, height, null);
- else if (extname.equalsIgnoreCase("png"))
- ChartUtilities.writeChartAsPNG(fos_jpg, chart, width, height, null);
- else System.out.print("文件名格式出错,只能以JPG或PNG结尾.");
- 5、如果是在tomcat工程中,可以在JSP页面中加入request.getContextPath()来获得当前工程的网址。
- .基本概念的理解
- 绝对路径:绝对路径就是你的主页上的文件或目录在硬盘上真正的路径,(URL和物理路径)例如:
C:/xyz/test.txt 代表了test.txt文件的绝对路径。http://www.sun.com/index.htm也代表了一个
URL绝对路径。 - 相对路径:相对与某个基准目录的路径。包含Web的相对路径(HTML中的相对目录),例如:在
Servlet中,"/"代表Web应用的跟目录。和物理路径的相对表示。例如:"./" 代表当前目录,
"../"代表上级目录。这种类似的表示,也是属于相对路径。 - 另外关于URI,URL,URN等内容,请参考RFC相关文档标准。
- RFC 2396: Uniform Resource Identifiers (URI): Generic Syntax,
(http://www.ietf.org/rfc/rfc2396.txt)
2.关于JSP/Servlet中的相对路径和绝对路径。- 2.1服务器端的地址
- 服务器端的相对地址指的是相对于你的web应用的地址,这个地址是在服务器端解析的
(不同于html和javascript中的相对地址,他们是由客户端浏览器解析的)也就是说这时候
在jsp和servlet中的相对地址应该是相对于你的web应用,即相对于http://192.168.0.1/webapp/的。 - 其用到的地方有:
forward:servlet中的request.getRequestDispatcher(address);这个address是
在服务器端解析的,所以,你要forward到a.jsp应该这么写:
request.getRequestDispatcher(“/user/a.jsp”)这个/相对于当前的web应用webapp,
其绝对地址就是:http://192.168.0.1/webapp/user/a.jsp。
sendRedirect:在jsp中<%response.sendRedirect("/rtccp/user/a.jsp");%> - 2.22、客户端的地址
- 所有的html页面中的相对地址都是相对于服务器根目录(http://192.168.0.1/)的,
而不是(跟目录下的该Web应用的目录)http://192.168.0.1/webapp/的。
Html中的form表单的action属性的地址应该是相对于服务器根目录(http://192.168.0.1/)的,
所以,如果提交到a.jsp为:action="/webapp/user/a.jsp"或action="<%=request.getContextPath()%>"/user/a.jsp;
提交到servlet为actiom="/webapp/handleservlet"
Javascript也是在客户端解析的,所以其相对路径和form表单一样。
因此,一般情况下,在JSP/HTML页面等引用的CSS,Javascript.Action等属性前面最好都加上
<%=request.getContextPath()%>,以确保所引用的文件都属于Web应用中的目录。
另外,应该尽量避免使用类似".","./","http://www.cnblogs.com/"等类似的相对该文件位置的相对路径,这样
当文件移动时,很容易出问题。
3. JSP/Servlet中获得当前应用的相对路径和绝对路径
3.1 JSP中获得当前应用的相对路径和绝对路径
根目录所对应的绝对路径:request.getRequestURI()
文件的绝对路径 :application.getRealPath(request.getRequestURI());
当前web应用的绝对路径 :application.getRealPath("/");
取得请求文件的上层目录:new File(application.getRealPath(request.getRequestURI())).getParent()- 3.2 Servlet中获得当前应用的相对路径和绝对路径
根目录所对应的绝对路径:request.getServletPath();
文件的绝对路径 :request.getSession().getServletContext().getRealPath
(request.getRequestURI())
当前web应用的绝对路径 :servletConfig.getServletContext().getRealPath("/");
(ServletContext对象获得几种方式:
javax.servlet.http.HttpSession.getServletContext()
javax.servlet.jsp.PageContext.getServletContext()
javax.servlet.ServletConfig.getServletContext()
) - 4.java 的Class中获得相对路径,绝对路径的方法
4.1单独的Java类中获得绝对路径
根据java.io.File的Doc文挡,可知:
默认情况下new File("/")代表的目录为:System.getProperty("user.dir")。
一下程序获得执行类的当前路径
package org.cheng.file;
import java.io.File; - public class FileTest {
public static void main(String[] args) throws Exception { - System.out.println(Thread.currentThread().getContextClassLoader().getResource(""));
- System.out.println(FileTest.class.getClassLoader().getResource(""));
- System.out.println(ClassLoader.getSystemResource(""));
System.out.println(FileTest.class.getResource(""));
System.out.println(FileTest.class.getResource("/")); //Class文件所在路径
System.out.println(new File("/").getAbsolutePath());
System.out.println(System.getProperty("user.dir"));
}
} - 4.2服务器中的Java类获得当前路径(来自网络)
(1).Weblogic - WebApplication的系统文件根目录是你的weblogic安装所在根目录。
例如:如果你的weblogic安装在c:/bea/weblogic700.....
那么,你的文件根路径就是c:/.
所以,有两种方式能够让你访问你的服务器端的文件:
a.使用绝对路径:
比如将你的参数文件放在c:/yourconfig/yourconf.properties,
直接使用 new FileInputStream("yourconfig/yourconf.properties");
b.使用相对路径:
相对路径的根目录就是你的webapplication的根路径,即WEB-INF的上一级目录,将你的参数文件放 - 在yourwebapp/yourconfig/yourconf.properties,
这样使用:
new FileInputStream("./yourconfig/yourconf.properties");
这两种方式均可,自己选择。 - (2).Tomcat
- 在类中输出System.getProperty("user.dir");显示的是%Tomcat_Home%/bin
- (3).Resin
- 不是你的JSP放的相对路径,是JSP引擎执行这个JSP编译成SERVLET
的路径为根.比如用新建文件法测试File f = new File("a.htm");
这个a.htm在resin的安装目录下 - (4).如何读相对路径哪?
- 在Java文件中getResource或getResourceAsStream均可
- 例:getClass().getResourceAsStream(filePath);//filePath可以是"/filename",这里的/代表web
- 发布根路径下WEB-INF/classes
- 默认使用该方法的路径是:WEB-INF/classes。已经在Tomcat中测试。
- 5.读取文件时的相对路径,避免硬编码和绝对路径的使用。(来自网络)
5.1 采用Spring的DI机制获得文件,避免硬编码。
参考下面的连接内容:
http://www.javajia.net/viewtopic.php?p=90213&
5.2 配置文件的读取
参考下面的连接内容:
http://dev.csdn.net/develop/article/39/39681.shtm
5.3 通过虚拟路径或相对路径读取一个xml文件,避免硬编码
参考下面的连接内容:
http://club.gamvan.com/club/clubPage.jsp?iPage=1&tID=10708&ccID=8 - 6.Java中文件的常用操作(复制,移动,删除,创建等)(来自网络)
常用 java File 操作类
http://www.easydone.cn/014/200604022353065155.htm - Java文件操作大全(JSP中)
http://www.pconline.com.cn/pcedu/empolder/gj/java/0502/559401.html - java文件操作详解(Java中文网)
http://www.51cto.com/html/2005/1108/10947.htm - JAVA 如何创建/删除/修改/复制目录及文件
http://www.gamvan.com/developer/java/2005/2/264.html