Java ialah bahasa pengaturcaraan merentas platform yang digunakan secara meluas dalam pembangunan aplikasi web, aplikasi mudah alih, aplikasi desktop dan bidang lain. Apabila pembangun Java menulis kod, mereka selalunya perlu menggunakan fail sifat untuk menyimpan maklumat konfigurasi, rentetan antarabangsa dan data lain. Walau bagaimanapun, aplikasi yang dibangunkan menggunakan Java 11 mungkin menghadapi ralat fail sifat UTF-8. Artikel ini akan menerangkan cara mengendalikan dan mengelakkan ralat fail sifat Java11 UTF-8.
1. Simptom ralat fail sifat UTF-8
Dalam Java11, jika anda menggunakan pengekodan UTF-8 untuk menyimpan fail sifat dan fail sifat mengandungi aksara Cina, Jepun dan bukan ASCII yang lain, anda mungkin menghadapi perkara berikut pengecualian:
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)
Sukar untuk melihat punca masalah dengan mesej pengecualian ini, tetapi melalui analisis kita boleh membuat kesimpulan berikut:
2. Bagaimana untuk mengelakkan ralat fail atribut UTF-8
Jika pengecualian di atas berlaku semasa menyimpan fail atribut menggunakan pengekodan UTF-8, anda boleh cuba menukar pengekodan atribut fail kepada ISO- 8859-1 atau GB2312 dan format pengekodan lain. Kedua-dua format pengekodan ini tidak menyokong aksara Unicode, jadi MalformedInputException tidak akan berlaku. Walau bagaimanapun, perlu diambil perhatian bahawa mengubah suai format pengekodan boleh menyebabkan aksara bukan ASCII hilang atau bercelaru.
Ubah suai kod yang membaca fail sifat untuk menggunakan set aksara yang betul untuk membaca fail sifat. Dalam Java11, apabila menggunakan kelas Properties untuk membaca fail harta, pengekodan ISO-8859-1 digunakan secara lalai, jadi aksara bercelaru mungkin muncul apabila membaca aksara bukan ASCII seperti bahasa Cina. Anda boleh menggunakan kod berikut untuk membaca fail sifat dalam 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);
Kaedah ini akan menetapkan format pengekodan fail sifat kepada UTF-8 untuk memastikan fail harta benda yang mengandungi aksara bukan ASCII seperti bahasa Cina boleh baca dengan betul.
3. Cara menangani ralat fail sifat UTF-8
Jika anda mengalami ralat fail sifat UTF-8, anda boleh menyelesaikannya melalui langkah berikut:
Gunakan Editor teks sewenang-wenangnya, buka fail sifat dan semak sama ada kandungan fail mengandungi aksara Cina, Jepun, Korea dan lain-lain aksara bukan ASCII. Jika fail sifat tidak mengandungi aksara ini, maka anda perlu menyemak masalah lain dalam kod tersebut.
Gunakan editor teks untuk membuka fail sifat dan semak format pengekodan fail. Jika ia dalam format pengekodan UTF-8 dan fail mengandungi aksara bukan ASCII, MalformedInputException mungkin berlaku.
Mengikut situasi tertentu, anda boleh memilih untuk mengubah suai format pengekodan fail hartanah atau membaca kod fail hartanah untuk mengelakkan atau menyelesaikan MalformedInputException pengecualian.
Ringkasnya, apabila menggunakan fail hartanah dalam format pengekodan UTF-8 dalam Java11, anda perlu memberi perhatian khusus kepada isu pengekodan set aksara. Menetapkan format pengekodan dan kod untuk membaca fail sifat dengan betul boleh mengelakkan masalah ralat fail sifat UTF-8 dengan berkesan.
Atas ialah kandungan terperinci Ralat Java: Ralat Fail Sifat Java11 UTF-8, Cara Mengendalikan dan Mengelak. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!