标签:
在学习时servlet乱码问题还是挺严重的,总结一下有三种情况
1.新建HTML页面后浏览出现乱码
2.以post形式请求时出现乱码
3.以get形式请求时出现乱码
让我们一个一个来解决吧
1.新建HTML页面后浏览出现乱码
<!DOCTYPE html>
<html>
<head>
<title>乱码示例</title>
<meta name="keywords" content="keyword1,keyword2,keyword3">
<meta name="description" content="this is my page">
<meta name="Content-Type"content="text/html;charset=utf-8">
</head>
<body>
Post示例 <br>
<form action="/EnocodingDemo/GetEncodingPage" method="post">
<label>信息:</label><input type="text" name="info"><br/>
<label>提交:</label> <input type="submit" value="提交">
</form>
</body>
</html>
我们新建一个网页后添加一些信息,用浏览器打开后发现会有乱码
遇到这种情况我们发现
代码里已经把charset设置成了utf-8了
<meta name="Content-Type"content="text/html;charset=utf-8">
但为什么不对呢?答案是它把标记用错了不应该用name要用http-equiv
把它修改成这样
<meta http-equiv="Content-Type"content="text/html;charset=utf-8">
重新reload一下,用ie打开
这里要及一下基础
name 属性提供了名称/值对中的名称。HTML 和 XHTML 标签都没有指定任何预先定义的 <meta> 名称。通常情况下,您可以自由使用对自己和源文档的读者来说富有意义的名称。 "keywords" 是一个经常被用到的名称。它为文档定义了一组关键字。某些搜索引擎在遇到这些关键字时,会用这些关键字对文档进行分类。
http-equiv 属性为名称/值对提供了名称。并指示服务器在发送实际的文档之前先在要传送给浏览器的 MIME 文档头部包含名称/值对。 当服务器向浏览器发送文档时,会先发送许多名称/值对。虽然有些服务器会发送许多这种名称/值对,但是所有服务器都至少要发送一个:content-type:text/html。这将告诉浏览器准备接受一个 HTML 文档。
它俩常用的名称为
详细请自己阅读 http://www.w3school.com.cn/tags/tag_meta.asp
2.以post形式请求时出现乱码
我们2.以post形式请求时出现乱码就用上面的HTML页面新建一个
新建一个servlet MyEncodingPage
POST请求的数据时作为请求体的一部分传递给服务器的,只要修改请求内的编码就可以。
request.setCharacterEncoding("UTF-8");
详细代码
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
request.setCharacterEncoding("UTF-8");
String info = request.getParameter("info");
out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");
out.println("<HTML>");
out.println(" <HEAD><TITLE>A Servlet</TITLE></HEAD>");
out.println(" <BODY>");
out.println("<h1>Hello</h1>");
out.println("info = "+info);
out.println(" </BODY>");
out.println("</HTML>");
out.flush();
out.close();
}
3.以get形式请求时出现乱码
在地址栏输入默认是gbk,而get传参数是要先编码为iso8859-1再传的,所以要先用iso-8859-1来解码,再用utf-8编码为一个新字符串
String str= new String(request.getParameter("name").getBytes("ISO-8859-1"), "UTF-8");
标签:
原文地址:http://www.cnblogs.com/jinzhiming/p/5366804.html