<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Java Votary

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      48 隨筆 :: 1 文章 :: 80 評論 :: 0 Trackbacks

    1.如何獲得當前文件路徑

    常用:

    字符串類型:System.getProperty("user.dir");

    綜合:

    package com.zcjl.test.base;
    import java.io.File;
    public class Test {
        public static void main(String[] args) throws Exception {
            System.out.println(
                Thread.currentThread().getContextClassLoader().getResource(""));
            System.out.println(Test.class.getClassLoader().getResource(""));
            System.out.println(ClassLoader.getSystemResource(""));
            System.out.println(Test.class.getResource(""));
            System.out.println(Test.class.getResource("/"));
            System.out.println(new File("").getAbsolutePath());
            System.out.println(System.getProperty("user.dir"));

        }
    }

    2.Web服務中

    (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

    (5).獲得文件真實路徑

    string  file_real_path=request.getRealPath("mypath/filename"); 

    通常使用request.getRealPath("/"); 

    3.文件操作的類

    import java.io.*;
    import java.net.*;
    import java.util.*;
    //import javax.swing.filechooser.*;
    //import org.jr.swing.filter.*;

    /**
    * 此類中封裝一些常用的文件操作。
    * 所有方法都是靜態方法,不需要生成此類的實例,
    * 為避免生成此類的實例,構造方法被申明為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可以直接在初始化參數中配置,調用時根據servlet的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");

    posted on 2005-12-16 22:53 Dion 閱讀(31501) 評論(8)  編輯  收藏 所屬分類: Java

    評論

    # re: 【轉載】關于Java文件路徑問題 2007-01-10 16:08 張秀蘭
    總結得好  回復  更多評論
      

    # re: 【轉載】關于Java文件路徑問題 2007-01-18 15:20 星月
    只要開心就好  回復  更多評論
      

    # re: 【轉載】關于Java文件路徑問題 2007-04-28 10:24 chirui
    3.只通過Java程序操作資源文件
    InputStream in = new FileInputStream("abc.properties"); // 放在classes同級

    OutputStream out = new FileOutputStream("abc.properties");
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~`

    這種方式拿不到文件
      回復  更多評論
      

    # re: 【轉載】關于Java文件路徑問題[未登錄] 2007-08-14 20:30 David
    可以找到 要注意 把這個abc文件放到和源文件編譯后的class文件一個目錄才行  回復  更多評論
      

    # re: 【轉載】關于Java文件路徑問題 2007-10-24 16:46 費啊
    sb  回復  更多評論
      

    # re: 【轉載】關于Java文件路徑問題[未登錄] 2008-04-17 09:12 YY
    cao
      回復  更多評論
      

    # re: 【轉載】關于Java文件路徑問題 2008-09-26 16:59 wuzhiwei
    我獲得不到相對路徑下的文件

    我的項目結構是

    a
    - xlsdown
    -query.xls

    a是項目名 xlsdown是項目下的一個文件夾 query是xls文件 , 現在我通過代碼來拿query.xls文件 找不到路徑。 為什么?
    我是這樣寫的:
    InputStream ins = new FileInputStream("./xlsdown/query.xls");

    我的QQ是 15159909 郵箱是 wuzhiwei4350232@126.com

    請幫我解答,謝謝!  回復  更多評論
      

    # re: 【轉載】關于Java文件路徑問題[未登錄] 2011-03-26 22:02 JAVA
    沒有說明FILE()怎么從硬盤讀取,沒有回答到點上  回復  更多評論
      

    主站蜘蛛池模板: 天天摸天天操免费播放小视频| 亚欧在线精品免费观看一区| 又粗又硬又大又爽免费视频播放| 亚洲性色精品一区二区在线| 欧洲黑大粗无码免费| 亚洲午夜无码久久久久小说| 永久久久免费浮力影院| 国产成人综合亚洲绿色| 亚洲福利视频一区二区| a毛片成人免费全部播放| 亚洲一区AV无码少妇电影☆| 国产亚洲免费的视频看| 亚洲视屏在线观看| AV大片在线无码永久免费| 亚洲欧美日韩中文无线码| 免费大片黄手机在线观看| 你懂的网址免费国产| 亚洲视屏在线观看| 免费观看四虎精品国产永久| 91av免费在线视频| 亚洲成年人免费网站| 日本最新免费不卡二区在线| WWW国产成人免费观看视频| 亚洲国产一区在线| 成人免费毛片内射美女-百度| 色偷偷噜噜噜亚洲男人| 在线播放亚洲第一字幕| 在线精品一卡乱码免费| 国产亚洲精品国产福利在线观看 | 亚洲国产中文v高清在线观看| 一级一级一级毛片免费毛片| 久久亚洲国产伦理| 国产男女性潮高清免费网站| 成人久久免费网站| 亚洲第一成年网站视频 | 成年在线观看免费人视频草莓| 美女被爆羞羞网站免费| 亚洲一区二区三区首页| 国产zzjjzzjj视频全免费| 日韩精品内射视频免费观看| 无码天堂亚洲国产AV|