当前位置: 首页 > news >正文

【自用】JavaSE--特殊文件Properties与XML、日志技术

特殊文件

概述

使用特殊文件可以存储多个有关系的数据,作为系统的配置信息

属性文件类似于键值对,一一对应存储数据(比如用户名与密码)

XML文件存储多个用户的多个属性更适合,适合存储更复杂的数据

Properties

注:这个属性文件的后缀即使不是properties也没关系,无所谓后缀,只要文件内容都是键值对,就可以使用Properties

读取Properties

示例代码:

public class test {public static void main(String[] args) {//创建properties对象Properties properties = new Properties();try (//创建输入流管道Reader rd = new FileReader("properties-XML-log\\src\\com\\CJ\\Proerties\\user.properties")){//将properties文件中的数据传到创建的properties对象中去properties.load(rd);System.out.println(properties);System.out.println(properties.getProperty("小陈"));//通过键找值//遍历全部值System.out.println("遍历全部键值对:");Set<String> set = properties.stringPropertyNames();//将所有键存到集合中for(String name : set){System.out.println("用户名:"+name+" 密码:"+properties.getProperty(name));System.out.println("----------");}//forEach方法遍历properties.forEach((k,v)->{System.out.println(k+":"+v);});} catch (Exception e) {e.printStackTrace();}}
}

写出Properties

示例:

案例

看看user属性文件中是否有大黑牛,有的话将他的密码改成233,没有的话就算了

public class test {public static void main(String[] args){try{String FILE_PATH = "properties-XML-log\\src\\com\\CJ\\Proerties\\user.properties";//文件路径Properties properties = new Properties();//创建对象properties.load(new FileReader(FILE_PATH));//将文件加载到对象中if(properties.containsKey("大黑牛")) {  //由于properties也属于map集合,因此可以使用map自带的containsKeyproperties.setProperty("大黑牛","233");//在对象中修改properties.store(new FileWriter(FILE_PATH),"修改成功");//写回属性文件System.out.println("修改完成!");}else System.out.println("没有找到大黑牛");} catch (Exception e) {e.printStackTrace();}}
}

注意:所有输出流在创建时默认都会清空文件(需要加上append才是追加),因此在面对需要修改文件的操作时要注意创建输出流的时间

XML

XML的创建

重点是后缀为  .xml

语法规则

 一定要有xml抬头声明,且放在第一行,如下图

用数据区挺不错的,可读性好

应用场景

读取XML中的数据

如果自己手写IO流代码来解析XML,难度相当大且繁琐

推荐使用开源的XML框架,最知名的是:Dom4j(第三方研发)

引入框架方法如下:

Dom4j的思想

常见方法

XML解析思想:自上而下,先拿文档,通过文档拿到根元素,通过根元素拿子元素,一级一级解析

案例:

public class test {public static void main(String[] args) throws Exception {//获得saxReader解析器SAXReader saxReader = new SAXReader();//通过解析器将xml读成document文档(会有异常,应该是怕你写到地址不对,抛出即可)Document document = saxReader.read("properties-XML-log\\test.xml");//获取根元素Element root = document.getRootElement();System.out.println(root.getName());//打印出根元素的名字看一下//通过根元素获取子元素,将所有子元素放入list中List<Element> elements = root.elements();for(Element e : elements){   //遍历所有子元素,即userList<Attribute> attributes = e.attributes();//获取当前遍历到user的全部属性,放入listSystem.out.print(e.getName()+":");for(Attribute a : attributes){  //通过遍历打印出全部属性System.out.print(a.getName()+"="+a.getText()+" ");}System.out.println();List<Element> es = e.elements();   //将当前遍历到user的全部信息放入listfor(Element e1 : es){    //将当前user的所有信息打印出来System.out.println(e1.getName()+":"+e1.getText());}System.out.println("---------");}}
}

运行结果:

XML的生成

不建议使用Dom4j,较繁琐

推荐直接把程序里的数据拼接成XML格式,然后使用IO流写出去

示例:

public class test {public static void main(String[] args){//使用StringBuffer进行拼接StringBuffer sb = new StringBuffer();sb.append("<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\r\n");sb.append("<book>\n");sb.append("\t<name>").append("假如我是一头大肥猪").append("</name>\r\n");sb.append("\t<author>").append("小肥猪").append("</author>\r\n");sb.append("\t<price>").append(19.9).append("</price>\r\n");sb.append("</book>");//采用IO流将他输出到外部文件try (BufferedWriter bw = new BufferedWriter(new FileWriter("properties-XML-log\\output.xml"))){bw.write(sb.toString());} catch (Exception e) {e.printStackTrace();}}
}

运行结果:

约束XML的编写(了解)

XML的约束就是限制XML文件只能按照某种格式进行书写

因此就需要用到约束文档,如DTD文档与Schema文档,如果不按照限制的要求来编写,就会出问题

DTD约束文档

缺点是不能约束具体数据类型,比如下面案例中的售价就算写我是一头大肥猪也没事

案例:

Schema约束文档

案例:

日志技术

概述

日志把程序运行的信息,记录到文件中,方便程序员定位bug、并了解程序的执行情况等

程序中的日志通常是一个文件,用来记录程序运行过程中的各种信息

之前学习中记录日志的方案:

之后要学习的日志技术的优点:

日志技术的体系

注:日志框架都是按照日志接口的标准来设计的,降低程序员学习成本

Logback日志框架

Logback快速入门

使用日志技术必须的操作:

logback.xml 一般是不用自己写,也不需要理解,稍微了解一下即可

温故知新:final关键字 --> 修饰变量时只能为其赋值一次,不能再赋值        

日志使用示例如下图,每次执行都会记录,我执行力两次

可以用info表示重要时间,erro表示错误,debug表示程序调试

核心配置文件logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration><!--CONSOLE :表示当前的日志信息是可以输出到控制台的。--><appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"><!--输出流对象 默认 System.out 改为 System.err--><target>System.out</target><encoder><!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符--><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5level]  %c [%thread] : %msg%n</pattern></encoder></appender><!-- File是输出的方向通向文件的 --><appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern><charset>utf-8</charset><!--输出的文件的编码方式--></encoder><!--日志输出路径--><file>D:/AJava/code/javasepro/log_test/src/log_test.log</file><!--指定日志文件拆分和压缩规则--><!--不采取拆分压缩,当执行力很久之后日志就会变得很大很大,浪费空间--><rollingPolicyclass="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"><!--通过指定压缩文件名称,来确定分割文件方式--><!--当日志文件达到指定的文件拆分大小后,就采用下行的规则进行拆分--><fileNamePattern>D:/AJava/code/javasepro/log_test/src/log_test-%i-%d{yyyy-MM-dd}-.log.gz</fileNamePattern><!--文件拆分大小--><maxFileSize>1MB</maxFileSize></rollingPolicy></appender><!--1、控制日志的输出情况:如,ALL开启日志,OFF取消日志--><root level="debug"><appender-ref ref="CONSOLE"/><appender-ref ref="FILE" /></root>
</configuration>

Logback设置日志级别

AI给出的记录范围:

注:

  • 大多数日志框架(如 SLF4J/Logback)不区分 FATAL,错误统一归为 ERROR
  • 支持FATAL的框架(如 Log4j 2)会将其视为比ERROR更严重的独立级别。

设置成 info 示例:

http://www.dtcms.com/a/334718.html

相关文章:

  • 《零基础掌握飞算Java AI:核心概念与案例解析》
  • Swift 实战:实现一个简化版的 Twitter(LeetCode 355)
  • Cohere 开发企业级大型语言模型(LLM)
  • Vue实例中的其他属性【5】
  • 安全审计-iptales防火墙设置
  • Java硬件融合实战:Vector API+ROCm加速大模型推理优化解锁AMD GPU异构算力,实现LLM本地化部署
  • Mysql常见的优化方法
  • OpenShift 4.19安装中的变化
  • 失落城堡2 送修改器(Lost Castle 2)免安装中文版
  • 安卓11 12系统修改定制化_____修改系统默认域名解析规则 实现屏蔽广告 屏蔽应用更新等功能
  • JavaScript手录17-原型
  • Java后台生成多个Excel并用Zip打包下载
  • 《AI 与数据质量的深度碰撞:颠覆传统治理模式的变革》文章提纲
  • 【C++语法】手写堆与有关堆的容器/函数
  • CMake进阶: 配置文件(configure_file)
  • 数据结构初阶(17)排序算法——非比较排序(计数排序·动图演示)、排序算法总结
  • 打卡day40
  • 在本地部署Qwen大语言模型全过程总结
  • Go语言panic机制详解
  • goland在windows上编译突然变慢
  • Spring Framework:Java 开发的基石与 Spring 生态的起点
  • [go] 桥接模式
  • Git代码库安装与管理常用操作
  • 同创物流学习记录1
  • 论文学习24:Boundary-Sensitive Segmentation of SmallLiver Lesions
  • 拒绝造轮子(C#篇)ZLG CAN卡驱动封装应用
  • 日语学习-日语知识点小记-进阶-JLPT-N1阶段蓝宝书,共120语法(2):11-20语法
  • 【星闪】Hi2821 | SysTick系统定时器
  • 《Python学习之字典(二):高级操作与实战技巧》
  • Python训练Day45