jarファイルでUTF-8からISO-8859-1に変換するコードには次のものがあります.Windowsでこのjarを実行すると、1つの結果が得られ、CentOSで別の結果が得られます。誰かが理由を知っているでしょうか?
public static void main(String[] args) {
try {
String x = "Ä, ä, É, é, Ö, ö, Ü, ü, ß, «, »";
Charset utf8charset = Charset.forName("UTF-8");
Charset iso88591charset = Charset.forName("ISO-8859-1");
ByteBuffer inputBuffer = ByteBuffer.wrap(x.getBytes());
CharBuffer data = utf8charset.decode(inputBuffer);
ByteBuffer outputBuffer = iso88591charset.encode(data);
byte[] outputData = outputBuffer.array();
String z = new String(outputData);
System.out.println(z);
}
catch(Exception e) {
System.out.println(e.getMessage());
}
}
Windows では、java -jar test.jar > test.txt により、Ä、ä、É、é、Ö、ö、Ü、ü、ß、«、» を含むファイルが作成されます。
しかし、CentOS では次のようになります: �?、ä、�?、é、�?、ö、�?、ü、�?、«、»