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 :
2. Comment éviter les erreurs du fichier d'attributs UTF-8
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.
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 :
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.
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.
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!