jsp两个文件:
表单 form.jsp
<%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %>
<!DOCtype html>
<html>
<head>
<title> 收集参数的表单页 </title>
<meta name="website" content="http://www.crazyit.org" />
</head>
<body>
<form action="request1.jsp" method="post">
用户名:<br/>
<input type="text" name="name"><hr/>
性别:<br/>
男:<input type="radio" name="gender" value="male">
女:<input type="radio" name="gender" value="female"><hr/>
喜欢的颜色:<br/>
红:<input type="checkbox" name="color" value="红色">
绿:<input type="checkbox" name="color" value="绿色">
蓝:<input type="checkbox" name="color" value="蓝色"><hr/>
来自的国家:<br/>
<select name="country">
<option value="中国">中国</option>
<option value="美国">美国</option>
<option value="俄罗斯">俄罗斯</option>
</select><hr/>
<input type="submit" value="提交">
<input type="reset" value="重置">
</form>
</body>
</html>
处理:request.jsp
<%@ page contentType="text/html; charset=UTF-8" language="java" errorPage="" %>
<%@ page import="java.util.*" %>
<!DOCTYPE html>
<html>
<head>
<title> 获取请求头/请求参数 </title>
<meta name="website" content="http://www.crazyit.org" />
</head>
<body>
<%
// 获取所有请求头的名称
Enumeration<String> headerNames = request.getHeaderNames();
while(headerNames.hasMoreElements())
{
String headerName = headerNames.nextElement();
// 获取每个请求、及其对应的值
out.println(
headerName + "-->" + request.getHeader(headerName) + "<br/>");
}
out.println("<hr/>");
// 设置解码方式,对于简体中文,使用GBK解码
request.setCharacterEncoding("GBK"); // ①
// 下面依次获取表单域的值
String name = request.getParameter("name");
String gender = request.getParameter("gender");
// 如果某个请求参数有多个值,将使用该方法获取多个值
String[] color = request.getParameterValues("color");
String national = request.getParameter("country");
%>
<!-- 下面依次输出表单域的值 -->
您的名字:<%=name%><hr/>
您的性别:<%=gender%><hr/>
<!-- 输出复选框获取的数组值 -->
您喜欢的颜色:<%for(String c : color)
{out.println(c + " ");}%><hr/>
您来自的国家:<%=national%><hr/>
</body>
</html>
乱码出现:
或者是这样:
当我把两个文件开头的page 的charset属性都改成UTF-8的时候,乱码依旧,我以为UTF-8是最大的字符集,应该管用,然而并不是。
最后探索到:其实文件本身也有一个编码格式的,当表单的请求数据传到处理jsp的过程中会以这种格式编码。(我猜的)
文件本身是什么格式,开头就要以什么格式:form.jsp文件是GBK编码的,所以page的charset要用GBK,而不能用UTF-8,否则乱码。
正常是这样:
不一致的时候乱码:
而request.jsp文件格式改成了UTF-8编码,所以page的charset要用UTF-8
用noteplus++改的:
也可以用sublime
正常输出:
用什么格式编码,就要以什么格式解码:所以在request.jsp中获取form.jsp的数据的编码格式要和from.jsp的编码格式相同,form.jsp是GBK编码的,所以这里要GBK格式获取: