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

    ①文件目录

    ②读取示例代码:

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

  • 相关阅读:
    java 多级图的最短路径
    在dos中编译java文件
    apollo客户端的长轮询机制的原理
    Apollo配置中心动态生效实现原理
    jmx_exporter+prometheus+grafana实现kafka metric监控
    XXL-JOB(1) 分布式任务系统选型和XXL-JOB介绍,这篇文章相当的经典呀
    grafana根据不同prometheus server统计数据
    XXL-JOB的使用教程
    普罗米修斯官方文档
    Prometheus标签的管理
  • 原文地址:https://www.cnblogs.com/nanyangke-cjz/p/7126192.html
Copyright © 2020-2023  润新知