


fichier de configuration des propriétés de l'opération Java
Il existe une classe Propriétés (Java.util.Properties) en Java, qui est principalement utilisée pour lire les fichiers de configuration Java et stocker certaines valeurs qui peuvent devoir être modifiées dans les propriétés pour la configuration, généralement sous forme de fichiers . fichiers de propriétés. , en fait, il s'agit d'un fichier texte ordinaire. Le format du contenu du fichier est le format "clé=valeur", et les informations d'annotation du texte peuvent être annotées avec "#". Essayez d'utiliser le format UTF-8 pour le stockage. Les classes fournies par jdk lui-même ont des défauts, nous utilisons donc généralement le framework commons-configuration pour l'analyse.
1.1.1. Diagramme de classes de propriétés
1.1.2. Lire le Configuration des propriétés fichierLa méthode la plus couramment utilisée est
1. Utilisez la méthode getResourceAsStream(String name) de la classe java.lang.Class
InputStream in = getClass().getResourceAsStream("File name" );
2. Utiliser l'opération de flux
InputStream in = new BufferedInputStream(new FileInputStream(filepath));
1.1.3. Inconvénients1. Le format doit être k=v ne peut pas contenir d'espaces.
2. Les valeurs modifiées ne peuvent pas être actualisées régulièrement (Par exemple, le programme de valeur de modification de l'environnement en ligne lit toujours l'ancienne valeur ). Vous devez écrire votre propre contrôle de programme.
3. Les valeurs sont toutes de type string et doivent être converties selon les besoins lorsqu'elles sont obtenues par vous-même.
Sur la base des lacunes ci-dessus, nous pouvons utiliser la classe org.apache.commons.configuration pour résoudre le problème. Ce qui suit est lu dans le développement quotidien : propriétés. Encapsulation.
1.1.4. Utilisation du framework de configuration commons1.1.4.1 mavenImportation de packages
.
<dependency> <groupId>commons-configuration</groupId> <artifactId>commons-configuration</artifactId> <version>1.8</version> </dependency>
package cn.xhgg.common.configuration; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import org.apache.commons.configuration.ConfigurationException; import org.apache.commons.configuration.PropertiesConfiguration; import org.apache.commons.configuration.reloading.FileChangedReloadingStrategy; import org.apache.commons.lang.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * 这个类型的配置,文件首先需要有配置文件,其次配置文件应该写入该类,再则配置文件的编码方式必须是UTF8 */ public class PropertiesConfigUtil { private static Logger log = LoggerFactory.getLogger(PropertiesConfigUtil.class); public static final String PROPS_SUFFIX = ".properties"; private static Map<String, PropertiesConfiguration> configMap = new ConcurrentHashMap<String, PropertiesConfiguration>(); private static PropertiesConfiguration getConfig(String configName) { //去除空格 configName = configName.trim(); //有后缀使用后缀 没后缀 添加后缀 String configSig = StringUtils.endsWith(configName, PROPS_SUFFIX) ? configName : configName+PROPS_SUFFIX; if (configMap.containsKey(configSig)) { return configMap.get(configSig); } PropertiesConfiguration config = null; try { config=new PropertiesConfiguration(); config.setEncoding("UTF-8"); config.load(configSig); //默认五秒检查一次 config.setReloadingStrategy(new FileChangedReloadingStrategy()); config.setThrowExceptionOnMissing(true); configMap.put(configSig, config); } catch (ConfigurationException e) { e.printStackTrace(); } return config; } public static Map<String, String> getKeyValuePairs(String configSig) { PropertiesConfiguration config = getConfig(configSig); if (config == null) { return null; } Iterator<String> iters = config.getKeys(); Map<String, String> retMap = new HashMap<String, String>(); while (iters.hasNext()) { String beforeKey = iters.next(); if (retMap.containsKey(beforeKey)) { log.warn(configSig + " configKey:" + beforeKey + " repeated!!"); } retMap.put(beforeKey, config.getString(beforeKey)); } return retMap; } /** * 通过PropertiesConfiguration取得参数的方法 * <p> * * @return 。 */ static public String getString(String configSig, String key) { return getConfig(configSig).getString(key); } static public String getString(String configSig, String key, String defaultValue) { return getConfig(configSig).getString(key, defaultValue); } static public int getInt(String configSig, String key) { return getConfig(configSig).getInt(key); } static public int getInt(String configSig, String key, int defaultValue) { return getConfig(configSig).getInt(key, defaultValue); } static public boolean getBoolean(String configSig, String key) { return getConfig(configSig).getBoolean(key); } static public boolean getBoolean(String configSig, String key, boolean defaultValue) { return getConfig(configSig).getBoolean(key, defaultValue); } static public double getDouble(String configSig, String key) { return getConfig(configSig).getDouble(key); } static public double getDouble(String configSig, String key, double defaultValue) { return getConfig(configSig).getDouble(key, defaultValue); } static public float getFloat(String configSig, String key) { return getConfig(configSig).getFloat(key); } static public float getFloat(String configSig, String key, float defaultValue) { return getConfig(configSig).getFloat(key, defaultValue); } static public long getLong(String configSig, String key) { return getConfig(configSig).getLong(key); } static public long getLong(String configSig, String key, long defaultValue) { return getConfig(configSig).getLong(key, defaultValue); } static public short getShort(String configSig, String key) { return getConfig(configSig).getShort(key); } static public short getShort(String configSig, String key, short defaultValue) { return getConfig(configSig).getShort(key, defaultValue); } static public List<Object> getList(String configSig, String key) { return getConfig(configSig).getList(key); } static public List<Object> getList(String configSig, String key, List<Object> defaultValue) { return getConfig(configSig).getList(key, defaultValue); } static public byte getByte(String configSig, String key) { return getConfig(configSig).getByte(key); } static public byte getByte(String configSig, String key, byte defaultValue) { return getConfig(configSig).getByte(key, defaultValue); } static public String[] getStringArray(String configSig, String key) { return getConfig(configSig).getStringArray(key); } }
propertiesfichier de test
rabbitmq.propertiesest configuré comme suit :
#rpc 模式rmq rpc.rabbit.host=l-opsdev3.ops.bj0.jd.com rpc.rabbit.port=5672 rpc.rabbit.username=jd_vrmphoto rpc.rabbit.password=jd_vrmphoto rpc.rabbit.vhost=jd/vrmphoto rpc.rabbit.queue=rpc_queue rpc.rabbit.exchange=photoworker rpc.rabbit.key=photoworker.rpc
PropertiesConfigUtil config=new PropertiesConfigUtil(); String username = config.getString("rabbitmq", "rpc.rabbit.username"); System.out.println(username);
Terminé.
1.1.4.5. Notes
1. Il est préférable d'unifier l'encodage avecUTF-8.
Sélection de la stratégie ReloadingStrategy. Vous pouvez consulter les classes d’implémentation spécifiques et les scénarios d’utilisation. J'utilise généralement la classe FileChangedReloadingStrategy. Ce qui précède est le contenu du fichier de configuration des propriétés de l'opération Java. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.php.cn) !
Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds



Guide de la racine carrée en Java. Nous discutons ici du fonctionnement de Square Root en Java avec un exemple et son implémentation de code respectivement.

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide du générateur de nombres aléatoires en Java. Nous discutons ici des fonctions en Java avec des exemples et de deux générateurs différents avec d'autres exemples.

Guide du numéro Armstrong en Java. Nous discutons ici d'une introduction au numéro d'Armstrong en Java ainsi que d'une partie du code.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est
