我们在以前讨论过在Web工程不能采用Java工程原先的读取方式,即创建一个文件流(FileInputStream)并给出一个文件目录(从src开始找一直找到你要读取文件的目录),这种的方式是不可行的。假如我们是在一个Servlet对象中取读取文件的话,我们就可以获取到ServletContext对象,然后通过getRealPath方法获取文件的实际路径,进而取创建文件流对象来操作文件,具体代码如下所示:
//获取文件的真实路径 String filePath = this.getServletContext().getRealPath("/WEB-INF/classes/com/servlet/jdbc3.properties"); //构建流对象 FileInputStream fis = new FileInputStream(filePath);
如果是在一个普通的Java类文件中,我们有时候也要它来操作文件,比如我们自己封装的DBUtils,里面需要从配置文件中读取数据库的相关配置信息,用户名、密码等,但是,它是不能获取到ServletContext对象的,也许有的朋友可能会想,你传入一个ServletContext对象进去不就可以了。但是这样做的话就不太合理,因为WEB层就侵入到了数据访问层,就会耦合在一起,不符合软件设计高内聚,低耦合的思想。所以这种方式是不推荐的,那么这种方式不行,那该怎么办呢?所以,我们可以通过下面的方式进行读取文件,来解决这一个问题。
1.读取src目录下的文件
①文件目录
②读取示例代码:
package com.util; import java.io.IOException; import java.io.InputStream; import java.util.Properties; public class JdbcUtils { public static void readFile1() throws IOException { // 通过class类的getResourceAsStream方法来进行读取jdbc1.properties,它读的是当前类所在的目录即WEB-INF/classes/com/util InputStream in = JdbcUtils.class.getResourceAsStream("jdbc1.properties"); Properties prop = new Properties(); prop.load(in); // 从控制台列出prop里面的信息 prop.list(System.out);
in.close(); } }
③运行结果:
-- listing properties --
jdbc.driver_class=oracle.jdbc.driver.OracleDriver
jdbc.connection.username=root
jdbc.connection.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.connection.password=root
2.读取src的包目录下的文件
①文件目录
②读取示例代码:
package com.util; import java.io.IOException; import java.io.InputStream; import java.util.Properties; public class JdbcUtils { public static void readFile2() throws IOException { // 通过类装载器来进行读取jdbc2.properties(文件不宜不过大,因为是通过加载类的方式去读),它读取的是目录是WEB-INF/classes InputStream in = JdbcUtils.class.getClassLoader().getResourceAsStream("jdbc2.properties"); Properties prop = new Properties(); prop.load(in); // 从控制台列出prop里面的信息 prop.list(System.out);
in.close(); } }
③运行结果:
-- listing properties --
jdbc.driver_class=oracle.jdbc.driver.OracleDriver
jdbc.connection.username=root
jdbc.connection.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.connection.password=root
至此在web中普通Java类读取文件的方式描述完毕,有不足的地方,希望大家多多提意见!