• <sub id="h4knl"><ol id="h4knl"></ol></sub>
    <sup id="h4knl"></sup>
      <sub id="h4knl"></sub>

      <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
      1. <strong id="h4knl"></strong>

      2. Java里處理文件的技巧

        時間:2024-08-29 00:45:36 JAVA認證 我要投稿
        • 相關推薦

        Java里處理文件的技巧

          在java里怎么處理文件呢?下面yjbys介紹一些利用JDK7標準庫來靈活處理文件的方法。希望對大家有幫助!

          實用的工具類,Path,Paths,Files,FileSystem

          有一些很靈活的處理方法:

          //得到一個Path對象

          Path path = Paths.get("/test/a.txt");

          //Path轉換File

          File file = path.toFile();

          Files.readAllBytes(path);

          Files.deleteIfExists(path);

          Files.size(path);

          正確拼接路徑不要手動拼接路徑

          不好的代碼:

          String game = "foo";

          File file = new File("~/test/" + game + ".txt");

          即使是要手動拼接路徑,請使用下面兩個平臺無關的變量:

          System.out.println(File.pathSeparator);

          System.out.println(File.separator);

          正確簡潔的方法是使用Paths類:

          Path path = Paths.get("~/test/", "foo", "bar", "a.txt");

          System.out.println(path);

          // ~/test/foo/bar/a.txt

          讀取文件的所有內容,文件的所有行

          讀取文件所有內容前,先判斷文件大小,防止OOM。

          public static byte[] readAllBytes(String fileName, long maxSize) throws IOException {

          Path path = Paths.get(fileName);

          long size = Files.size(path);

          if (size > maxSize) {

          throw new IOException("file: " + path + ", size:" + size + "> " + maxSize);

          }

          return Files.readAllBytes(path);

          }

          public static List readAlllines(String fileName, Charset charset, long maxSize) throws IOException {

          Path path = Paths.get(fileName);

          long size = Files.size(path);

          if (size > maxSize) {

          throw new IOException("file: " + path + ", size:" + size + "> " + maxSize);

          }

          return Files.readAllLines(path, charset);

          }

          利用JDK7的特性,auto close,遠離一堆的catch, close

          Path path = Paths.get("~/test/", "foo", "bar", "a.txt");

          try (InputStream in = Files.newInputStream(path)) {

          // process

          //in.read();

          }

          歷遍目錄

          DK7新特性,FileVisitor

          public class MyFileVisitor extends SimpleFileVisitor{

          @Override

          public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException {

          System.out.println(file);

          return FileVisitResult.CONTINUE;

          }

          public static void main(String[] args) throws IOException {

          Path path = Paths.get("/home/user/test");

          Files.walkFileTree(path, new MyFileVisitor());

          }

          }

          判斷文件是否在父路徑下

          網上流傳一種遞歸判斷parent的方式,http://stackoverflow.com/questions/18227634/check-if-file-is-in-subdirectory

          但是查閱jdk代碼后,發現getParent()函數是通過處理文件名得到的。所以直接比較文件前綴即可。

          請務必注意,file.getCanonicalPath()函數 。

          public static boolean isSubFile(File parent, File child) throws IOException {

          return child.getCanonicalPath().startsWith(parent.getCanonicalPath());

          }

          public static boolean isSubFile(String parent, String child) throws IOException {

          return isSubFile(new File(parent), new File(child));

          }

          監視文件改變

          JDK7新特性,但是API比較難用。TODO

          淘寶有個diamond的配置管理項目,是利用定時器不斷去讀取來文件是否改變的。

          JDK7則是利用了linux的inotify機制。

          Web服務器防止非法的文件路徑訪問

          字符截斷攻擊和文件歷遍漏洞原理:在文件名中插入%00的URL編碼,web服務器會把%00后面的內容拋棄。

          例如這樣的URL:http://www.test.com/../../../../etc/passwd%00.gif

          防范方法

          寫入文件前,判斷文件是否在父路徑下,參考上面的函數。

          利用Java的安全機制

          // All files in /img/java can be read

          grant codeBase "file:/home/programpath/" {

          permission java.io.FilePermission "/img/java", "read";

          };

          Tomcat的設置

          http://tomcat.apache.org/tomcat-7.0-doc/security-manager-howto.html

          靜態資源不要自己手寫代碼去讀取,盡量使用Web服務器或者Web框架的本身的靜態資源映射功能。

          比如Tomcat的默認自帶的DefaultServlet:

          default

          /static/*

          Spring mvc可以配置

          或者使用spring mvc里的DefaultServletHttpRequestHandler。這個默認優先級是最低的,也就是最后沒人處理的URL會交給WebServer本身的default servlet去處理。比如Tomcat的就是上面所說的。

          個人推薦使用DefaultServletHttpRequestHandler,因為Web容器的文件訪問功能要比Spring mvc自身的要強大。比如Tomcat的DefaultServlet支持Etag,斷點續傳,緩存等。

          參考:

          http://docs.spring.io/spring/docs/current/spring-framework-reference/html/mvc.html

          http://svn.apache.org/repos/asf/tomcat/trunk/Java/org/apache/catalina/servlets/DefaultServlet.java

        《&.doc》
        将本文的Word文档下载到电脑,方便收藏和打印
        推荐度:
        点击下载文档

        【Java里處理文件的技巧】相關文章:

        Java讀取xml文件的方法07-20

        sun認證java關于字符串處理技巧06-01

        Java文件解壓縮示例08-21

        sun認證考試java關于字符串處理技巧06-22

        學習Java的技巧07-30

        java學習技巧09-13

        學習java技巧09-23

        電腦里哪些文件屬于垃圾文件10-12

        Java如何讀取文件內容再編輯10-16

        JAVA認證基礎知識:Java文件解壓縮示例10-14

        在线咨询
        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码
      3. <sub id="h4knl"><ol id="h4knl"></ol></sub>
        <sup id="h4knl"></sup>
          <sub id="h4knl"></sub>

          <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
          1. <strong id="h4knl"></strong>

          2. 欧美香蕉免费在线视频观看 | 亚洲中文字幕网址在线 | 欧美.亚洲.日本视频 | 中文字幕一级大片 | 日本久久久免费精品 | 一本久久a久久免费精品顶级 |

            Java里處理文件的技巧

              在java里怎么處理文件呢?下面yjbys介紹一些利用JDK7標準庫來靈活處理文件的方法。希望對大家有幫助!

              實用的工具類,Path,Paths,Files,FileSystem

              有一些很靈活的處理方法:

              //得到一個Path對象

              Path path = Paths.get("/test/a.txt");

              //Path轉換File

              File file = path.toFile();

              Files.readAllBytes(path);

              Files.deleteIfExists(path);

              Files.size(path);

              正確拼接路徑不要手動拼接路徑

              不好的代碼:

              String game = "foo";

              File file = new File("~/test/" + game + ".txt");

              即使是要手動拼接路徑,請使用下面兩個平臺無關的變量:

              System.out.println(File.pathSeparator);

              System.out.println(File.separator);

              正確簡潔的方法是使用Paths類:

              Path path = Paths.get("~/test/", "foo", "bar", "a.txt");

              System.out.println(path);

              // ~/test/foo/bar/a.txt

              讀取文件的所有內容,文件的所有行

              讀取文件所有內容前,先判斷文件大小,防止OOM。

              public static byte[] readAllBytes(String fileName, long maxSize) throws IOException {

              Path path = Paths.get(fileName);

              long size = Files.size(path);

              if (size > maxSize) {

              throw new IOException("file: " + path + ", size:" + size + "> " + maxSize);

              }

              return Files.readAllBytes(path);

              }

              public static List readAlllines(String fileName, Charset charset, long maxSize) throws IOException {

              Path path = Paths.get(fileName);

              long size = Files.size(path);

              if (size > maxSize) {

              throw new IOException("file: " + path + ", size:" + size + "> " + maxSize);

              }

              return Files.readAllLines(path, charset);

              }

              利用JDK7的特性,auto close,遠離一堆的catch, close

              Path path = Paths.get("~/test/", "foo", "bar", "a.txt");

              try (InputStream in = Files.newInputStream(path)) {

              // process

              //in.read();

              }

              歷遍目錄

              DK7新特性,FileVisitor

              public class MyFileVisitor extends SimpleFileVisitor{

              @Override

              public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException {

              System.out.println(file);

              return FileVisitResult.CONTINUE;

              }

              public static void main(String[] args) throws IOException {

              Path path = Paths.get("/home/user/test");

              Files.walkFileTree(path, new MyFileVisitor());

              }

              }

              判斷文件是否在父路徑下

              網上流傳一種遞歸判斷parent的方式,http://stackoverflow.com/questions/18227634/check-if-file-is-in-subdirectory

              但是查閱jdk代碼后,發現getParent()函數是通過處理文件名得到的。所以直接比較文件前綴即可。

              請務必注意,file.getCanonicalPath()函數 。

              public static boolean isSubFile(File parent, File child) throws IOException {

              return child.getCanonicalPath().startsWith(parent.getCanonicalPath());

              }

              public static boolean isSubFile(String parent, String child) throws IOException {

              return isSubFile(new File(parent), new File(child));

              }

              監視文件改變

              JDK7新特性,但是API比較難用。TODO

              淘寶有個diamond的配置管理項目,是利用定時器不斷去讀取來文件是否改變的。

              JDK7則是利用了linux的inotify機制。

              Web服務器防止非法的文件路徑訪問

              字符截斷攻擊和文件歷遍漏洞原理:在文件名中插入%00的URL編碼,web服務器會把%00后面的內容拋棄。

              例如這樣的URL:http://www.test.com/../../../../etc/passwd%00.gif

              防范方法

              寫入文件前,判斷文件是否在父路徑下,參考上面的函數。

              利用Java的安全機制

              // All files in /img/java can be read

              grant codeBase "file:/home/programpath/" {

              permission java.io.FilePermission "/img/java", "read";

              };

              Tomcat的設置

              http://tomcat.apache.org/tomcat-7.0-doc/security-manager-howto.html

              靜態資源不要自己手寫代碼去讀取,盡量使用Web服務器或者Web框架的本身的靜態資源映射功能。

              比如Tomcat的默認自帶的DefaultServlet:

              default

              /static/*

              Spring mvc可以配置

              或者使用spring mvc里的DefaultServletHttpRequestHandler。這個默認優先級是最低的,也就是最后沒人處理的URL會交給WebServer本身的default servlet去處理。比如Tomcat的就是上面所說的。

              個人推薦使用DefaultServletHttpRequestHandler,因為Web容器的文件訪問功能要比Spring mvc自身的要強大。比如Tomcat的DefaultServlet支持Etag,斷點續傳,緩存等。

              參考:

              http://docs.spring.io/spring/docs/current/spring-framework-reference/html/mvc.html

              http://svn.apache.org/repos/asf/tomcat/trunk/Java/org/apache/catalina/servlets/DefaultServlet.java