现在我们来解决万恶的jsp中文显示问题
<%@page contentType="text/html; charset=gb2312"%>
<% request.setCharacterEncoding("gb2312");%>
然后在<Title></Title>的后面加上
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
tomcat5.5下测试通过
真恶心
----------------------------------华丽地分割----------------------------------------------------------------
对于request post,get方法传过来的参数
out.print( (String)request.getParameter("name") );
String tmp_p=(String)request.getParameter("name");
byte[] tmp_t=tmp_p.getBytes("ISO8859-1");
String tmp=new String(tmp_t);
out.println(tmp);
进行内码转换后可以正常显示
再附上网上摘来的两个解析
2、对于从网页中的文本框通过String parameter = request.getParameter("parameter");方 式获得的字符串,均是iso-8859-1的编码,如果想把它显示在网页上就必须得用parameter = new String (parameter.getBytes("iso-8859-1","GB2312")进行转换,windows和linux这两种系统都是一样的。有 一个简单方法,就是在getParameter()方法获取参数之前,使用 request.setCharacterEncoding("GB2312");,将提交的信息转为GB2312编码。
3、但是对于数据写入数据库的问题,采取的方式就不同了: windows了下,必须要采用该字符串转换再插入数据库,而linux下就不需要,而是直接把iso-8859-1编码的字符插入,如果从数据库中读出 的数据,对于windwos因为在插入时已经做了转换,所以读出时已经是GB2312的了, 当把它显示在网页上时,不需要做编码转换,而在linux上的mysql中的数据是iso-8859-1的所以要做编码的转换。
<%@page contentType="text/html; charset=gb2312"%>
<% request.setCharacterEncoding("gb2312");%>
然后在<Title></Title>的后面加上
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
tomcat5.5下测试通过
真恶心
----------------------------------华丽地分割----------------------------------------------------------------
对于request post,get方法传过来的参数
out.print( (String)request.getParameter("name") );
String tmp_p=(String)request.getParameter("name");
byte[] tmp_t=tmp_p.getBytes("ISO8859-1");
String tmp=new String(tmp_t);
out.println(tmp);
进行内码转换后可以正常显示
再附上网上摘来的两个解析
2、对于从网页中的文本框通过String parameter = request.getParameter("parameter");方 式获得的字符串,均是iso-8859-1的编码,如果想把它显示在网页上就必须得用parameter = new String (parameter.getBytes("iso-8859-1","GB2312")进行转换,windows和linux这两种系统都是一样的。有 一个简单方法,就是在getParameter()方法获取参数之前,使用 request.setCharacterEncoding("GB2312");,将提交的信息转为GB2312编码。
3、但是对于数据写入数据库的问题,采取的方式就不同了: windows了下,必须要采用该字符串转换再插入数据库,而linux下就不需要,而是直接把iso-8859-1编码的字符插入,如果从数据库中读出 的数据,对于windwos因为在插入时已经做了转换,所以读出时已经是GB2312的了, 当把它显示在网页上时,不需要做编码转换,而在linux上的mysql中的数据是iso-8859-1的所以要做编码的转换。