我在Java文件编码方面遇到了问题。
我有一个Java程序会将输入流保存为具有给定文件名的文件,代码片段如下:
File out = new File(strFileName);
Files.copy(inStream, out.toPath());
除非文件名包含Ö
之类的特殊字符,否则它在Windows上运行正常,文件名中包含这些字符,保存的文件将在Windows上显示乱码文件名。
我理解通过应用JVM选项-Dfile.encoding=UTF-8
可以修复此问题,但我会在我的代码中找到一个解决方案,而不是要求所有用户更改其JVM选项。
在调试程序时,我可以看到文件名字符串总是显示正确的字符,所以我猜问题不在于内部编码。
有人可以解释一下幕后出了什么问题吗?有没有办法以编程方式避免这个问题?我尝试从字符串中获取字节并更改编码,但它不起作用。
感谢。
答案 0 :(得分:0)
使用URLEncoder class可行:
String name = URLEncoder.encode("fileName#", "UTF-8");
File output = new File(name);