Maison  >  Article  >  Java  >  Erreur Java : erreur du fichier de propriétés Java11 UTF-8, comment gérer et éviter

Erreur Java : erreur du fichier de propriétés Java11 UTF-8, comment gérer et éviter

WBOY
WBOYoriginal
2023-06-25 09:26:271584parcourir

Java est un langage de programmation multiplateforme largement utilisé dans le développement d'applications Web, d'applications mobiles, d'applications de bureau et d'autres domaines. Lorsque les développeurs Java écrivent du code, ils doivent souvent utiliser des fichiers de propriétés pour stocker les informations de configuration, les chaînes internationalisées et d'autres données. Cependant, les applications développées à l'aide de Java 11 peuvent rencontrer des erreurs de fichier de propriétés UTF-8. Cet article explique comment gérer et éviter les erreurs du fichier de propriétés Java11 UTF-8.

1. Symptômes des erreurs de fichier de propriétés UTF-8

Dans Java11, si vous utilisez le codage UTF-8 pour enregistrer un fichier de propriétés et que le fichier de propriétés contient des caractères chinois, japonais et autres caractères non-ASCII, vous pouvez rencontrer ce qui suit exception :

java.nio.charset.MalformedInputException: Input length = 1
at java.base/java.nio.charset.CoderResult.throwException(CoderResult.java:274)
at java.base/sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:339)
at java.base/sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178)
at java.base/java.io.InputStreamReader.read(InputStreamReader.java:185)
at java.base/java.io.BufferedReader.fill(BufferedReader.java:161)
at java.base/java.io.BufferedReader.readLine(BufferedReader.java:326)
at java.base/java.io.BufferedReader.readLine(BufferedReader.java:392)

Il est difficile de voir la cause première du problème avec ce message d'exception, mais grâce à l'analyse, nous pouvons tirer les conclusions suivantes :

  • Lors de la lecture du fichier de propriétés, Java11 utilise l'encodage UTF-8 par défaut.
  • Dans le processus de lecture du fichier de propriétés, Java le lira octet par octet selon les règles d'encodage UTF-8.
  • Si une séquence d'octets contenant des caractères non-ASCII est lue, Java tentera de la convertir en caractères Unicode.
  • Si la séquence d'octets lue ne peut pas être décodée en caractères Unicode selon les règles de codage UTF-8, une exception MalformedInputException sera levée.

2. Comment éviter les erreurs du fichier d'attributs UTF-8

  1. Modifier l'encodage du fichier d'attributs

Si l'exception ci-dessus se produit lors de l'enregistrement du fichier d'attributs à l'aide de l'encodage UTF-8, vous pouvez essayer de modifier l'encodage du fichier d'attributs. fichier d'attributs à ISO-8859-1 ou GB2312 et à d'autres formats de codage. Ces deux formats de codage ne prennent pas en charge les caractères Unicode, donc MalformedInputException ne se produira pas. Cependant, il convient de noter que la modification du format d'encodage peut entraîner la perte ou l'altération des caractères non-ASCII.

  1. Modifiez le code qui lit le fichier de propriétés

Modifiez le code qui lit le fichier de propriétés pour utiliser le jeu de caractères correct pour lire le fichier de propriétés. Dans Java11, lors de l'utilisation de la classe Properties pour lire des fichiers de propriétés, le codage ISO-8859-1 est utilisé par défaut, de sorte que des caractères tronqués peuvent apparaître lors de la lecture de caractères non-ASCII tels que le chinois. Vous pouvez utiliser le code suivant pour lire les fichiers de propriétés au format UTF-8 :

InputStream inputStream = this.getClass().getResourceAsStream("/test.properties");
Reader reader = new InputStreamReader(inputStream, StandardCharsets.UTF_8);
Properties properties = new Properties();
properties.load(reader);

Cette méthode définira le format d'encodage du fichier de propriétés sur UTF-8 pour garantir que les fichiers de propriétés contenant des caractères non-ASCII tels que le chinois peuvent être lus. correctement.

3. Comment gérer les erreurs du fichier de propriétés UTF-8

Si vous avez rencontré une erreur de fichier de propriétés UTF-8, vous pouvez la résoudre en suivant les étapes suivantes :

  1. Confirmez si le fichier de propriétés contient des caractères non-ASCII.

Utilisez un éditeur de texte arbitraire, ouvrez le fichier de propriétés et vérifiez si le contenu du fichier contient des caractères chinois, japonais, coréens et d'autres caractères non-ASCII. Si le fichier de propriétés ne contient pas ces caractères, vous devez rechercher d'autres problèmes dans le code.

  1. Confirmez le format d'encodage du fichier de propriétés

Utilisez un éditeur de texte pour ouvrir le fichier de propriétés et vérifiez le format d'encodage du fichier. S'il est au format de codage UTF-8 et que le fichier contient des caractères non-ASCII, une exception MalformedInputException peut se produire.

  1. Modifiez le format d'encodage du fichier de propriétés ou lisez le code du fichier de propriétés

Selon la situation spécifique, vous pouvez choisir de modifier le format d'encodage du fichier de propriétés ou de lire le code du fichier de propriétés pour éviter ou résoudre l'exception MalformedInputException exception.

En bref, lorsque vous utilisez des fichiers de propriétés au format d'encodage UTF-8 en Java11, vous devez accorder une attention particulière à la question de l'encodage du jeu de caractères. Définir correctement le format d'encodage et le code de lecture du fichier de propriétés peut efficacement éviter le problème des erreurs du fichier de propriétés UTF-8.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn