失恋了.....
延迟更新......
抱歉大家!!!!!
对于Java由于默认的编码方式是UNICODE,所以用中文也易出问题,常见的解决是
Strings2=newString(s1.getBytes(“ISO-8859-1”),”GBK”);
前三种方法是我比较常用的方法,别人的经验告诉我:通常get方法通过改server.xml解决,
post方法通过过滤器或者设置字符集解决,呵呵,不知道是否可行!
1、utf8解决JSP中文乱码问题
一般说来在每个页面的开始处,加入:
<%@pagelanguage="java"contentType="text/html;charset=UTF-8"
pageEncoding="UTF-8"%>
<%
request.setCharacterEncoding("UTF-8");
%>
charset=UTF-8的作用是指定JSP向客户端输出的编码方式为“UTF-8”
pageEncoding="UTF-8"为了让JSP引擎能正确地解码含有中文字符的JSP页面,这在LINUX中很有效
request.setCharacterEncoding("UTF-8");是对请求进行了中文编码
有时,这样仍不能解决问题,还需要这样处理一下:
Stringmsg=request.getParameter("message");
Stringstr=newString(msg.getBytes("ISO-8859-1"),"UTF-8");
out.println(st);
2、Tomcat5.5中文乱码(利用tomcat已经写好的字符集过滤器)
1)只要把%TOMCAT安装目录%/webapps/servlets-examples/WEB-INF/classes/filters/SetCharacterEncodingFilter.class文件拷到你的webapp目录/filters下,如果没有filters目录,就创建一个。
2)在你的web.xml里加入如下几行:
<filter>
<filter-name>SetCharacterEncoding</filter-name>
<filter-class>filters.SetCharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>