.properties is a file extension for files mainly used in Java-related technologies to store the configurable parameters of an application. They can also be used for storing strings for Internationalization and localization; these are known as Property Resource Bundles.
Each parameter is stored as a pair of strings, one storing the name of the parameter (called the key), and the other storing the value.
Each line in a .properties file normally stores a single property. Several formats are possible for each line, including
key = value,
key value. Single-quotes or double-quotes are considered part of the string. Trailing space is significant and presumed to be trimmed as required by the consumer.
Comment lines in .properties files are denoted by the number sign (#) or the exclamation mark (!) as the first non blank character, in which all remaining text on that line is ignored. The backwards slash is used to escape a character. An example of a properties file is provided below.
# You are reading the ".properties" entry. ! The exclamation mark can also mark text as comments. # The key characters =, and : should be written with # a preceding backslash to ensure that they are properly loaded. # However, there is no need to precede the value characters =, and : by a backslash. website = https://en.wikipedia.org/ language = English # The backslash below tells the application to continue reading # the value onto the next line. message = Welcome to \ Wikipedia! # But if the number of backslashes at the end of the line is even, the next line is not included in the value. In the following example, the value for "key" is "valueOverOneLine\" key = valueOverOneLine\\ # This line is not included in the value for "key" # Add spaces to the key key\ with\ spaces = This is the value that could be looked up with the key "key with spaces". # The characters = and : in the key must be escaped as well: key\:with\=colonAndEqualsSign = This is the value for the key "key:with=colonAndEqualsSign" # Unicode tab : \u0009 # If you want your property to include a backslash, it should be escaped by another backslash path=c:\\wiki\\templates # However, some editors will handle this automatically
In the example above, website would be a key, and its corresponding value would be https://en.wikipedia.org/. While the number sign (#) and the exclamation mark (!) marks text as comments, it has no effect when it is part of a property. Thus, the key message has the value Welcome to Wikipedia! and not Welcome to Wikipedia. All of the whitespace in front of Wikipedia! is excluded completely.
Before Java 9, the encoding of a .properties file is ISO-8859-1, also known as Latin-1. All non-ASCII characters must be entered by using Unicode escape characters, e.g. \uHHHH where HHHH is a hexadecimal index of the character in the Unicode character set. This allows for using .properties files as resource bundles for localization. A non-Latin-1 text file can be converted to a correct .properties file by using the native2ascii tool that is shipped with the JDK or by using a tool, such as po2prop, that manages the transformation from a bilingual localization format into .properties escaping.
An alternative to using unicode escape characters for non-Latin-1 character in ISO 8859-1 character encoded Java *.properties files is to use the JDK's XML Properties file format which by default is UTF-8 encoded, introduced starting with Java 1.5.
Another alternative is to create custom control that provides custom encoding.
Third-party tools are also available with additional functionality specific to editing .properties files such as:
- Data Validation
- Creating new keys
- Synchronization of key names
- Automatic bi-directional conversion of non-ASCII symbols to support non-Latin languages
- Integration with Eclipse
Non-Java uses and exceptions
- Translate Toolkit's po2prop converts native character encodings in a Gettext PO file into correctly escaped ascii without the need for native2ascii
- Java XML Properties DTD
- "java - How to use UTF-8 in resource properties with ResourceBundle". Stack Overflow. Archived from the original on 2015-03-25. Retrieved 2015-01-28.
- "Internationalization Enhancements in JDK 9". Oracle Help Center. Retrieved 2018-01-05.
- "JEP 226: UTF-8 Property Resource Bundles". OpenJDK. Retrieved 2020-09-03.
- "IResourceBundle". Adobe ActionScript® 3 (AS3 Flex) API Reference.
- "uriworkermap.properties configuration". The Apache Tomcat Connectors - Reference Guide.
- "Config::Properties - Read and write property files". metacpan.org.
- "SAPUI5 SDK - Demo Kit". sapui5.hana.ondemand.com. Retrieved 2019-05-14.
java.util.Properties.load(java.io.Reader)- gives the precise semantics of well-formed Java property files
java.util.PropertyResourceBundle- describes property resource bundles
java.util.Properties- explains Java properties in a simple XML format.
- MultiProperties - It is an Eclipse plugin for editing multiple key-value based files with similar content. This kind of file format can be Properties for example in Java programming language, which is frequently used for backing a ResourceBundle.
- Bracket Properties - a refresh of the Properties concept while keeping the ubiquitous .properties file format intact.
- Java Properties Editor (Application + Eclipse plugin) - useful utility to view and to edit properties files in a whole project.
- DOKSoft Properties Editor Eclipse plugin - i18n tool for installing into Eclipse IDE.
- Message Editor - it manages i18n for Java application. It generates XML property files. It includes two stylesheets for .properties and .xml property generation at compile time (Ant based.)
- JLokalize - open source Java properties editor with reversal function and spell check
- Config::Properties - Perl CPAN.
- Jackson Properties module is a library that allows mapping Properties file contents into Java Objects and back, similar to how XML and JSON is commonly mapped
- Localizely, POEditor, Lokalise, Loco, and Crowdin - developer-friendly translation and localisation tools that support .properties files.
- SAPUI5 - Use of Localized Texts in Applications