Java研学-配置文件

一 配置文件

1 作用–解决硬编码的问题

  在实际开发中,有时将变量的值直接定义在.java源文件中;如果维护人员想要修改数据,无法完成(因为没有修改权限),这种操作称之为硬编码

2 执行原理:

  将经常需要改变的数据定义在指定类型的文件中,通过java代码对指定的类型的文件进行操作

  核心技术:IO流 – 输入字节流 – InputStream对象

3 分类

  ① .properties : 文件类型:对应ava中定义好Properties类,他是一个集合类;是Map集合的一个具体实现类;以K-V键值对形式存储,呈现一一对应的映射关系;其中KEY和VALUE只支持String类型

  ② .xml:文件类型;可扩展标记(标签)语言;以标签的形式进行存储;与HTML一样

二 .properties文件

1 编写指定的.properties文件 – 首先在项目下创建一个resource文件夹(固定名称,与src同级)

2 将该文件夹通过Mark Directory as中的Resources Root设置为资源文件夹

在这里插入图片描述

3 于该文件夹中创建.properties文件(文件需符合小驼峰命名法,且文件后缀也要写)

在这里插入图片描述

4 获取配置文件中的数据

配置文件

# 只支持String类型,故不需定义数据类型,"",注意不要多出空格
water=water
fire=fire

Test类

//方式1:将配置文件加载到InputStream对象中,需写绝对路径
public class Test {
    public static void main(String[] args) {
        InputStream is=null;
        try {
            is=new FileInputStream("D:\\Java\\workspace\\untitled1\\resource\\play.properties");
            // 定义properties集合
            Properties p=new Properties();
            // 通过集合对象的方法,将流中的数据加载到集合中
            p.load(is);
            // public String getProperty(String key)  通过key获取value
            // public Object get(String key)    通过key获取value
            System.err.println(p.getProperty("water"));
            System.err.println(p.getProperty("fire"));
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

// 方式2:通过类加载器  ClassLoader对象(JVM提供)
public class Test {
    public static void main(String[] args) {
        // 反射机制 ClassLoader cl=类名.class.getClassLoader();
        // 通过当前执行线程对象获取 ClassLoader cl=Thread.currentThread().getContextClassLoader();
        ClassLoader cl=Test.class.getClassLoader();
        // 通过类加载器对象调用方法,将指定的配置文件加载到InputStream对象中
        InputStream is=cl.getResourceAsStream("play.properties");
        // 定义集合
        Properties p=new Properties();
        try {
            p.load(is);
            System.out.println(p.getProperty("water"));
            System.out.println(p.getProperty("fire"));
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if(is!=null){
                try {
                    is.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

三 .xml文件应用

1 概述:可扩展标记(标签)语言;由W3C组织编写,定义定规范;支持自定义标签(支持中文标签),创建方式与.properties相同(后缀改为.xml)

2 格式:

<标签名></标签名> – 没有特殊要求都是双标签

<标签名/> – 单标签,当且仅当标签之间没有编写文本内容,可以使用单标签

<?xml version="1.0" encoding="UTF-8"?>
<!--xml文件第一行是文档说明 version是xml的版本号 encoding是xml的字符编码集-->
<!--一个xml只有一个根标签:体现该xml的作用,可通过tab快捷键生成标签-->
<Water><!--区分大小写,类似Java的类-->
    <water>
        <name>大黄</name>
        <kg>24</kg>
    </water>
    <water>
        <name>大白</name>
        <kg>30</kg>
    </water>
</Water>

3 DOM方式–解析标签类型文件(.xml文件或.html文件)

  概述:Document Object Model文档对象模型,将指定的配置文件(Document)通过对象(Object)的方式,按照指定规则(Model)进行操作
  它将整个页面抽象为一棵树(读取XML或HTML文档,将其转换为一个DOM树,解析DOM树,将其转换为一个内存中的树形结构),开发者可以通过操作树上的节点来改变页面的内容、结构和样式,并将修改后的DOM树重新渲染到页面上。DOM树的根节点是document对象,它代表整个文档。每个节点都有自己的属性和方法,可以通过这些属性和方法来操作节点。

  主要操作标签与文本内容,前提是操作语言必须支持面向对象编程方式,文件必须是标记(标签)类型的文件(主干-根标签,枝干-子标签,叶子-标签中的文本内容)

// 通过DOM对指定的xml文件进行crud操作

// 获取并打印二号小动物的名字
public class DemoTest {

    @Test
    public void getName() throws Exception {
        // 获取配置文件对象
        // 获取文件构建工厂对象
        DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
        // 根据工厂对象获取文件构建对象
        DocumentBuilder db=dbf.newDocumentBuilder();
        // 根据文件构建对象获取文件对象
        Document doc=db.parse("resource/play.xml");
        // 根据文件对象获取根标签
        Element root=doc.getDocumentElement();
        // 通过根标签获取指定位置上的元素  Node 父节点 Element 子元素
        NodeList animals=root.getElementsByTagName("animal");
        // 自0计算
        Element a2= (Element) animals.item(1);
        // 根据指定学生标签获取指定的name标签
        Element name= (Element) a2.getElementsByTagName("name").item(0);
        // 根据name标签获取文本内容
        System.err.println("name="+name.getTextContent());
    }
}

// 增加一个小动物
public class DemoTest {
    @Test
    public void addAnimal() throws Exception {
        // 获取文件对象
        DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
        DocumentBuilder db=dbf.newDocumentBuilder();
        Document doc=db.parse("resource/play.xml");
        // 通过文档对象创建Animal对应的标签
        Element animal=doc.createElement("animal");
        Element name=doc.createElement("name");
        Element kg=doc.createElement("kg");
        // 给标签设置对应的文本内容
        name.setTextContent("小花");
        kg.setTextContent("11");
        // 将子标签name,kg追加到animal的尾部
        animal.appendChild(name);
        animal.appendChild(kg);
        // 通过文档对象获取根标签并将animal标签追加到根标签尾部
        Element animals=doc.getDocumentElement();
        animals.appendChild(animal);
        // 此时后端操作完成,需通过回写刷新xml
        // 获取回写工厂对象
        TransformerFactory tff=TransformerFactory.newInstance();
        // 通过工厂对象获取回写对象
        Transformer tf=tff.newTransformer();
        // 通过回写对象调用Document对象中的内容完成回写xml
        // Source xmlSource 后端操作 Result outputTarget 写入xml中
        tf.transform(new DOMSource(doc),new StreamResult(new File("resource/play.xml")));
        System.out.println("OK");
    }
}

// 修改2号小动物的体重
public class DemoTest {
    @Test
    public void replaceKg() throws Exception {
        // 获取文件对象
        DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
        DocumentBuilder db=dbf.newDocumentBuilder();
        Document doc=db.parse("resource/play.xml");
        // 根标签
        Element animals=doc.getDocumentElement();
        // 通过根标签获取所有动物子标签查询指定动物
        Element a2= (Element) animals.getElementsByTagName("animal").item(1);
        // animal标签中的kg标签只有一个故item为0
        Element kg= (Element) a2.getElementsByTagName("kg").item(0);
        kg.setTextContent("20");
        // 获取回写对象
        TransformerFactory tff=TransformerFactory.newInstance();
        Transformer tf=tff.newTransformer();
        tf.transform(new DOMSource(doc),new StreamResult(new File("resource/play.xml")));
        System.out.println("OK");
    }
}

// 删除2号小动物
public class DemoTest {
    @Test
    public void removeAnimal() throws Exception {
        // 获取文件对象
        DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
        DocumentBuilder db=dbf.newDocumentBuilder();
        Document doc=db.parse("resource/play.xml");
        // 根标签
        Element animals=doc.getDocumentElement();
        // 获取子标签
        Element a2= (Element) animals.getElementsByTagName("animal").item(1);
        // 根标签调用方法删除子标签 父一级删除子一级
        animals.removeChild(a2);
        // 获取回写对象
        TransformerFactory tff=TransformerFactory.newInstance();
        Transformer tf=tff.newTransformer();
        tf.transform(new DOMSource(doc),new StreamResult(new File("resource/play.xml")));
        System.out.println("OK");
    }
}

4 xml中约束

约束:规范指定编程语言或文件的编写格式

xml约束:由w3c组织规定,规定xml语言格式

xml约束分类 – 一般是下载网络上编写好的约束文件①.dtd ②.schema

四 封装工具类

1 作用

  重复操作(获取文档对象+回写文件)会导致配置文件加载次数过多,此时需要通过 jar包(需要大量API)或者工具类 (针对某个操作)简化代码

2 工具类定义

① 将指定配置文件加载定义到static代码块中(只加载一次,优先加载)

② 提供获取文档对象的方法和回写xml文档的方法

封装工具类

① 编写.properties文件,配置指定的xml文件的路径

# xml的路径     xmlPath.properties
path=resource/play.xml

② 编写工具类

public abstract class DOMUtils {
    private static String path;
    private static Document doc;  //导入w3c包的doc
    // 指定配置文件只需优先加载一次
    static{
        ClassLoader cl=DOMUtils.class.getClassLoader();
        InputStream is=cl.getResourceAsStream("xmlPath.properties");
        Properties p=new Properties();
        try {
            p.load(is);
            path=p.getProperty("path");
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if(is!=null){
                try {
                    is.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
    // 根据路径获取xml对应的Document对象
    public static Document getDoc() throws Exception{
        DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
        DocumentBuilder db=dbf.newDocumentBuilder();
        doc=db.parse(new File(path));
        return doc;
    }

    // 回写xml方法
    public static void writeForXml() throws Exception{
        TransformerFactory tff=TransformerFactory.newInstance();
        Transformer tf=tff.newTransformer();
        tf.transform(new DOMSource(doc),new StreamResult(new File(path)));
    }
}

② 测试

public class DemoTest {
    @Test
    public void playUtils() throws Exception {
        // 获取文档对象
        Document doc= DOMUtils.getDoc();
        // 通过文档对象创建子标签
        Element animal=doc.createElement("animal");
        Element name=doc.createElement("name");
        Element kg=doc.createElement("kg");
        // 为子标签设置内容
        name.setTextContent("煤球");
        kg.setTextContent("16");
        // 子标签追加
        animal.appendChild(name);
        animal.appendChild(kg);
        // 跟标签追加
        Element animals=doc.getDocumentElement();
        animals.appendChild(animal);
        // 回写xml
        DOMUtils.writeForXml();
        System.out.println("OK");
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/210725.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

(C语言)找出1-99之间的全部同构数

同构数&#xff1a;它出现在平方数的右边。例&#xff1a;5是25右边的数&#xff0c;25是625右边的数&#xff0c;即5和25均是同构数。 #include<stdio.h> int main() {for(int i 1;i < 100;i ){if((i*i % 10 i) || (i*i % 100 i))printf("%d\t%d\n",i,…

神经网络(第三周)

一、简介 1.1 非线性激活函数 1.1.1 tanh激活函数 使用一个神经网络时&#xff0c;需要决定在隐藏层上使用哪种激活函数&#xff0c;哪种用在输出层节点上。到目前为止&#xff0c;只用过sigmoid激活函数&#xff0c;但是&#xff0c;有时其他的激活函数效果会更好。tanh函数…

图文深入理解TCP三次握手

前言 TCP三次握手和四次挥手是面试题的热门考点&#xff0c;它们分别对应TCP的连接和释放过程&#xff0c;今天我们先来认识一下TCP三次握手过程&#xff0c;以及是否可以使用“两报文握手”建立连接&#xff1f;。 1、TCP是什么&#xff1f; TCP是面向连接的协议&#xff0c;…

Asp.Net Core Web Api内存泄漏问题

背景 使用Asp.Net Core Web Api框架开发网站中使用到了tcp socket通信&#xff0c;网站作为服务端开始tcp server&#xff0c;其他的客户端不断高速给它传输信息时&#xff0c;tcp server中读取信息每次申请的byte[]没有得到及时的释放&#xff0c;导致内存浪费越来越多&#…

从cmd登录mysql

说明 先看看mysql.exe文件在哪个目录下&#xff0c;为了后面的操作方便&#xff0c;可以将该文件所在的路径增加到环境变量path中。 如果不增加到path环境变量中&#xff0c;那么在cmd窗口就要切换到mysql.exe文件所在的目录下执行。 在cmd窗口查看mysql命令的帮助信息 在cm…

vue中实现纯数字键盘

一、完整 代码展示 <template><div class"login"><div class"login-content"><img class"img" src"../../assets/image/loginPhone.png" /><el-card class"box-card"><div slot"hea…

【蓝桥杯软件赛 零基础备赛20周】第6周——栈

文章目录 1. 基本数据结构概述1.1 数据结构和算法的关系1.2 线性数据结构概述1.3 二叉树简介 2. 栈2.1 手写栈2.2 CSTL栈2.3 Java 栈2.4 Python栈 3 习题 1. 基本数据结构概述 很多计算机教材提到&#xff1a;程序 数据结构 算法。 “以数据结构为弓&#xff0c;以算法为箭”…

Linux shell中的函数定义、传参和调用

Linux shell中的函数定义、传参和调用&#xff1a; 函数定义语法&#xff1a; [ function ] functionName [()] { } 示例&#xff1a; #!/bin/bash# get limit if [ $# -eq 1 ] && [ $1 -gt 0 ]; thenlimit$1echo -e "\nINFO: input limit is $limit" e…

Python程序员入门指南:就业前景

文章目录 标题Python程序员入门指南&#xff1a;就业前景Python 就业数据Python的就业前景SWOT分析法Python 就业分析 标题 Python程序员入门指南&#xff1a;就业前景 Python是一种流行的编程语言&#xff0c;它具有简洁、易读和灵活的特点。Python可以用于多种领域&#xff…

Zabbix HA高可用集群搭建

Zabbix HA高可用集群搭建 Zabbix HA高可用集群搭建一、Zabbix 高可用集群&#xff08;Zabbix HA&#xff09;二、部署Zabbix高可用集群1、两个服务端配置1.1主节点 Zabbix Server 配置1.2 备节点 Zabbix Server 配置1.3 主备节点添加监控主机1.4 查看高可用集群状态 2、两个客户…

二、ZooKeeper集群搭建

目录 1、概述 2、安装 2.1 第一步&#xff1a;下载zookeeeper压缩包 2.2 第二步&#xff1a;解压 2.3 第三步&#xff1a;修改配置文件 2.4 第四步&#xff1a;添加myid配置 ​​​​​​​2.5 第五步&#xff1a;安装包分发并修改myid的值 ​​​​​​​2.6 第六步&a…

NXP iMX8M Plus Qt5 双屏显示

By Toradex胡珊逢 简介 双屏显示在显示设备中有着广泛的应用&#xff0c;可以面向不同群体展示特定内容。文章接下来将使用 Verdin iMX8M Plus 的 Arm 计算机模块演示如何方便地在 Toradex 的 Linux BSP 上实现在两个屏幕上显示独立的 Qt 应用。 硬件介绍 Verdin iMX8M Plu…

C++11 类的新功能

新的默认成员函数 C11在6个默认成员函数基础上又加了两个:移动构造函数和移动赋值函数 针对移动构造函数和移动赋值运算符重载有一些需要注意的点如下&#xff1a; 小结&#xff1a; &#xff08;1&#xff09; 生成默认移动构造的条件比较严苛&#xff1a;必须是没有实现析…

微软推出免费网站统计分析工具 Clarity

给大家推送一个福利&#xff0c;最近微软正式对外推出免费网站统计分析工具 Clarity&#xff0c;官方网站是&#xff1a;https://clarity.microsoft.com. 任何用户都可以直接使用&#xff0c;主打一个轻松写意——真的是傻瓜式&#xff0c;没有任何多余的步骤&#xff0c;你唯一…

上门服务系统|北京上门服务系统开发功能及特点

上门护理同城服务系统是一种以社区为基础、以提供上门护理服务为核心的服务体系。上门服务软件是一种基于移动互联网技术的服务平台&#xff0c;旨在提供高效、便捷、安全的上门服务体验。 该软件具有以下特点&#xff1a; 1、便捷性&#xff1a;用户只需在手机上安装该软件&a…

快速上手PostMan,了解PostMan的基本使用

快速上手PostMan PostMan是一个可扩展的API开发和测试协同平台工具有网页版和独立客户端,推荐安装独立客户端 创建WorkSpace工作空间 类似于GitHub的个人空间可以起到云备份的作用 发送请求 发送Get请求 发送Post请求,设置请求体的格式是表单数据即namevalue的格式 发送Pos…

【 RTTI 】

RTTI 概念&#xff1a; RTTI(Run Time Type Identification)即通过运行时类型识别&#xff0c;程序能够使用基类的指针或引用来检 查着这些指针或引用所指的对象的实际派生类型。 原因&#xff1a; C是一种静态类 型语言。其数据类型是在编译期就确定的&#xff0c;不能在运…

一文教你使用STM32CubeMX开发工具

刚开始学习 STM32 的时候&#xff0c;不知道大家有没被外设驱动支配过的恐惧&#xff1f; 那么多的外设&#xff0c;那么多的选项&#xff0c;有可能一个选项没配置对&#xff0c;外设就工作不正常了&#xff0c;大大增加我们入行的难度。 针对这个问题&#xff0c;ST 公司很…

递归实例化导致的栈溢出问题【简直蠢得出奇】

问题描述 今天在练习数据库增删改查&#xff0c;体验三层架构思想时&#xff0c;随便写了点DAO层代码&#xff0c;但服务器运行时竟然爆出了栈溢出的问题&#xff0c;说实话&#xff0c;空指针问题我还能放着耐心去代码里找找问题&#xff0c;但这个栈溢出&#xff0c;我之前就…

如何获取唐诗三百首中的名句列表接口

唐诗三百首&#xff0c;是中国文学中最为经典的诗歌选集之一&#xff0c;其中涵盖了大量美丽、深刻的诗句&#xff0c;被广泛传诵。有不少文化爱好者希望能够获取这些名句列表&#xff0c;以便深入理解唐诗的内涵和精华。那么&#xff0c;如何获取唐诗三百首中的名句列表呢&…