在Web工程中,普通Java类如何读文件

   我们在以前讨论过在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目录下的文件

①文件目录

在Web工程中,普通Java类如何读文件

②读取示例代码:

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的包目录下的文件

①文件目录

在Web工程中,普通Java类如何读文件

②读取示例代码:

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类读取文件的方式描述完毕,有不足的地方,希望大家多多提意见!