乱码产生的原因是数据发送方和接收方使用了不同字符集进行解析。解决乱码的思路是确保数据发送方和接收方统一使用utf-8编码。
中文乱码问题的产生原因
- 数据的发送方和接收方使用不同的字符集进行解析时,会产生乱码。
- 浏览器和服务器端编码不匹配是常见的乱码问题原因
java
package com.imooc.servlet.encoding;
// 引入必要的Java类
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
// 使用@WebServlet注解来配置Servlet的访问路径为 "/encoding/search"
@WebServlet("/encoding/search")
public class SearchServlet extends HttpServlet {
// 重写HttpServlet的doGet方法,用于处理GET请求
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 获取GET请求中的参数"keyword"
// 在Tomcat 8以后,默认对GET请求的参数使用UTF-8编码进行解析
// 在Tomcat 8以前,默认使用ISO-8859-1编码,需要在server.xml中配置字符集
String keyword = request.getParameter("keyword");
// 输出获取到的关键字到控制台,可能会出现乱码
System.out.println(keyword);
// 设置响应的内容类型和字符编码,表示返回HTML格式的文本内容,并确保浏览器以UTF-8解码
response.setContentType("text/html;charset=utf-8");
// 向客户端返回一个HTML格式的文本响应,输出获取到的关键字
response.getWriter().println(keyword);
}
// 重写HttpServlet的doPost方法,用于处理POST请求
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 设置请求体的字符编码为UTF-8,用于正确解析POST请求中的参数
// 这样可以避免POST请求中的中文参数出现乱码
request.setCharacterEncoding("UTF-8");
// 获取POST请求中的参数"keyword",使用设置的UTF-8编码解析
String keyword = request.getParameter("keyword");
// 输出获取到的关键字到控制台,确保不会出现乱码
System.out.println(keyword);
// 设置响应的内容类型和字符编码,表示返回HTML格式的文本内容,并确保浏览器以UTF-8解码
response.setContentType("text/html;charset=utf-8");
// 向客户端返回一个HTML格式的文本响应,输出获取到的关键字
response.getWriter().println(keyword);
}
}