您的位置:首页 > Web前端 > JavaScript

JSP乱码

2015-07-20 17:02 465 查看
1.      
用户访问servlet

http://10.50.118.27:8080/TestWeb/mxGraph/examples/TestServlet

servlet跳转到jsp页面,页面无法正确显示中文

跳转方式:request.getRequestDispatcher("graphlayout-jsp.jsp").forward(request, response);

 

jsp页面内容如下(已设置utf-8):

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>测试</h1>
</body>
</html>

 

 

如果采用直接访问jsp的方式,页面显示正常:
http://localhost:8080/TestWeb/mxGraph/examples/graphlayout-jsp.jsp
 

 

经查询,有几个设置项会影响页面显示:

1.Eclipse的general>content types >jsp 
编码改成utf-8 记得点击后面的update按钮;

2.      
Eclipse下的web>jsp  的encoding改为utf-8

 

3.      
修改后记得重新创建jsp,再将原页面内容copy进来

4.      
修改工程的编码方式utf-8

 

 

 

5.      
修改Eclipse首选项的workspace的编码utf-8

6.      
修改tomcat和java
虚拟机的启动参数,增加

-Dfile.encoding="UTF-8"

也可以在tomcat的apache-tomcat-7.0.62\bin\ catalina.bat或者catalina.sh中修改

CATALINA_OPTS和JAVA_OPTS,这个网上说的很多,但是改了也没成功,标记下,待以后再遇到问题详细了解

7.      
以上这些步骤似乎只能解决jsp直接访问乱码的问题,要根本解决servlet跳转jsp的乱码问题还需要在跳转前做转码:

response.setCharacterEncoding("UTF-8");

request.setCharacterEncoding("UTF-8");

request.getRequestDispatcher("graphlayout-jsp.jsp").forward(request, response);

 

===============================================================================

解决问题过程中看到的比较好的内容,暂存:

 
正确设置-Dfile.encoding参数
 

  问题:

     项目在本机开发编译打包后发布到法国的服务器,代码中的中文全部乱码,就算是最简单的代码System.out.println("中文"),打印出来的也是乱码。

 

代码在本地的服务器测试都正常。

 

法国服务器的环境:window 2003
中文版。

 

解决:

 

在网友imasmallbird的指引下,发现是2个服务器的file.encoding的不同,本地服务器是GBK,而法国服务器是Cp1252,所以会产生乱码。

 

把法国服务器的区域设置改成中国后,file.encoding就变成GBK,这样可以解决这个问题,但因为很多原因不能直接改区域设置,比如改了区域设置后时间就不是法国时间。

 

目前解决办法如下:

1. 本地编译打包不用变,本地编译采用的是GBK编译的(默认采用系统字符集编译)

 

2. 在法国服务器的tomcat上加上JAVA的启动参数 -Dfile.encoding=GBK

 

重启tomcat,一切正常了。

 

解决了该问题后,顺便找了些JAVA的中文乱码的资料看了下,简单的总结下:

 

从Java 源代码到得到正确的结果,要经过“Java
源代码-> Java 字节码->
虚拟机->操作系统->显示设备”的过程。在上述过程中的每一步骤,我们都必须正确地处理中文的编码,才能够使最终显示正确的结果。

 

"Java 源代码-> Java
字节码":该阶段就是调用javac
进行编译的阶段,javac默认采用系统字符集,比如我们本地机器急就是GBK,如果想用其他的编码,比如UTF-8,可以加上 -encoding UTF-8

 

"Java 字节码->
虚拟机->操作系统"
:该阶段首先需要JRE或者JDK支持多语言(下载JRE的时候会让你选择英文版还是多语言版),然后就是虚拟机启动的时候使用什么字符集,默认也是采用当前系统的字符集,如需要修改字符集,加上JAVA的启动参数,-Dfile.encoding=GBK

 

"操作系统->显示设备":该阶段主要就是需要操作系统支持显示中文就可以,就是安装了中文字体。

 

看到这里后重新看我们的乱码问题,我们在本地编译(Java
源代码-> Java 字节码阶段)默认采用了GBK字符集,而"Java
字节码-> 虚拟机->操作系统"
阶段是在法国服务器上进行,也是采用了默认的字符集,但这里的默认字符集确实Cp1252,因字符集不一致,所以就会乱码。

 

 

 

 

 

System.getProperty("file.encoding") 得到当前系统字符集

content.getBytes(System.getProperty("file.encoding")),"GBK")
通过当前字符集转码
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: