0

0

Java中的Properties类应用_读取并操作.properties配置文件的步骤

P粉602998670

P粉602998670

发布时间:2026-02-17 08:12:10

|

181人浏览过

|

来源于php中文网

原创

properties.load()抛ioexception主因是路径错误和编码不匹配:默认iso-8859-1解码utf-8文件会乱码或报错;应优先用load(reader)指定utf-8编码,classpath资源须用getresourceasstream()获取流。

java中的properties类应用_读取并操作.properties配置文件的步骤

Properties.load() 读取文件时抛出 IOException:路径和编码是主因

Java 的 Properties 默认用 ISO-8859-1 解码,而你编辑的 .properties 文件大概率是 UTF-8(尤其含中文)。直接 load(InputStream) 会乱码甚至报 java.io.IOException: Invalid Unicode sequence

常见错误现象:key=value 看起来正常,但 getProperty("中文键") 返回 null;或加载时直接抛异常。

  • 优先用 load(Reader) 替代 load(InputStream),显式指定编码: props.load(new InputStreamReader(inputStream, "UTF-8"))
  • 资源在 classpath 下(如 src/main/resources/config.properties),别用 new FileInputStream("config.properties") —— 路径错、打包后找不到。改用: getClass().getResourceAsStream("/config.properties")
  • 如果必须用 load(InputStream)(比如兼容旧逻辑),确保文件里中文用 Unicode 转义(\u4f60\u597d),但不推荐——难维护

setProperty() 后如何保存到文件:注意流关闭和编码一致性

Properties.setProperty() 只改内存对象,不自动写回磁盘。调用 store() 才真正落盘,但默认又切回 ISO-8859-1,中文会变问号。

使用场景:运行时动态更新配置并持久化(如管理后台修改开关)。

立即学习Java免费学习笔记(深入)”;

360智绘
360智绘

360智脑推出的AI绘画创作与分享平台

下载
  • store(Writer, String),而非 store(OutputStream, String)props.store(new FileWriter("config.properties", false), "updated by Java")
  • 如果文件已存在且含中文,FileWriter 默认用系统编码(Windows 是 GBK),可能污染内容。稳妥做法: new OutputStreamWriter(new FileOutputStream("config.properties"), "UTF-8")
  • store() 会覆盖整个文件,不会只改某一行。别指望它做“增量保存”

getProperty() 返回 null 的三种真实原因

不是所有 null 都是键不存在。容易误判,导致空指针或逻辑跳过。

  • 键存在但值为空字符串(key=):getProperty("key") 返回 "",不是 null
  • 键存在但值为 key= 后跟空格(key= ):仍返回 " ",不是 null
  • 真正返回 null 的只有两种情况:键未定义;或键定义了但被注释掉(#key=value!key=value)——注释行不参与加载

所以判断是否存在,别只靠 == null,要结合 containsKey() 或检查原始行内容(需自己解析)。

Properties 不是 Map 的安全替代品:线程和类型隐患

虽然 Properties 继承自 Hashtable,但它的设计目标只是配置读写,不是通用容器。

  • 多线程写入(如多个地方调用 setProperty() + store())会竞争同一文件,没内置锁。得自己加同步或用临时文件+原子重命名
  • getProperty() 返回 String,但 get(key)(继承自 Map)返回 Object,混用易引发 ClassCastException
  • 加载时遇到语法错误(如等号前有空格、反斜杠未转义),load() 会静默跳过整行,不报错也不警告——配置丢了都不知道

复杂配置建议换 Apache Commons ConfigurationTypesafe ConfigProperties 适合简单、静态、单线程场景。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

750

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

244

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

746

2024.03.01

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

553

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

216

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1553

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

640

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

925

2024.03.22

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.6万人学习

C# 教程
C# 教程

共94课时 | 9.6万人学习

Java 教程
Java 教程

共578课时 | 67万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号