请求页面,例如: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");
总结:希望我们平时在处理中文乱码的时候,多理解一些原理的东西,将问题更好的解决。