请求页面,例如:HTML:
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
content指定的是浏览器编码格式,菜单栏->查看->编码,与上面设置的编码格式一致。
JSP:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
JSP默认pageEncoding = "ISO-8859-1",主要用于JSP文件character encoding.
<%@ page contentType="text/html;charset=UTF-8" %>
contentType指定的是从JSP返回到浏览器编码格式,菜单栏->查看->编码,与上面设置的编码格式一致。
<%
//分两种情况讨论,
//---------第一种方式,适合post和get---------
//设置字符编码依据:请求页面中的content类型
//request.setCharacterEncoding("UTF-8");
//获取form表单中的参数值
//String corpName = request.getParameter("corpName");
//System.out.println("corpName:"+corpName);
//---------第二种方式,只适合post---------
String corpName = request.getParameter("corpName");
//因为TOMCAT处理提交的参数时默认的是ISO-8859-1,
//所以转码都是从ISO-8859-1转到另一个编码格式
//另一编码格式判断依据是:请求页面中的content类型
//corpName = new String(corpName.getBytes("ISO-8859-1"),"UTF-8");
//{
//如果要适合get方式
corpName = java.net.URLDecoder.decode(corpName, "UTF-8");
//}
System.out.println("corpName:"+corpName);
out.println("corpName:"+corpName);
%>
另外说明一种情况是:使用window.location.href= url; url中传参数并且含有中文的情况,
例如:javascript 代码:
window.location.href = encodeURI(encodeURI(hello.jsp?name=世界))
java代码:
String name = request.getParameter("name");
name= java.net.URLDecoder.decode(name, "UTF-8");
总结:希望我们平时在处理中文乱码的时候,多理解一些原理的东西,将问题更好的解决。
1万+

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



