关于中文的乱码问题原因
response缓冲区的默认编码是iso8859-1,此码表中没有中文。
解决方法
可以通过response的setCharacterEncoding(String charset)设置response的编码。
response.setCharacterEncoding("UTF-8");
如果此时客户端还是不能正常显示中文。
原因: 虽然我们将response的缓冲区编码设置成UTF-8,但是浏览器的默认编码是本地系统的编码,因为我们都是中文系统,所以客户端浏览器的默认编码是GBK。
解决方法1:
手动修改浏览器的编码为UTF-8
解决方法2:
通过response的setContentType(String type)方法只当页面解析时的编码为UTF-8
response.setContentType("text/html;charset=UTF-8");
该方法不仅可以指定浏览器解析页面时的编码,同时也包含setCharacterEncoding的功能,所以在实际开发中
只要编写response.setContentType("text/html;charset=UTF−8");\color{red}{只要编写 response.setContentType("text/html;charset=UTF-8");}只要编写response.setContentType("text/html;charset=UTF−8");就可以解决中文乱码问题。
本文详细解释了中文乱码的原因,即response缓冲区的默认编码iso8859-1不支持中文。提供了两种解决方案,一是通过response的setCharacterEncoding方法设置编码为UTF-8,二是同时使用setContentType方法确保浏览器解析页面时的编码一致。
559

被折叠的 条评论
为什么被折叠?



