javaweb之解决HttpServletResponse输出的中文乱码问题

首先,response返回有两种,一种是字节流outputstream,一种是字符流printwrite。

申明:这里为了方便起见,所有输出都统一用UTF-8编码。

先说字节流,要输出“中国",给输出流的必须是转换为utf-8的“中国”,还要告诉浏览器,用utf8来解析数据

       //这句话的意思,是让浏览器用utf8来解析返回的数据
        response.setHeader("Content-type", "text/html;charset=UTF-8");
        String data = "中国";
        OutputStream ps = response.getOutputStream();
        //这句话的意思,使得放入流的数据是utf8格式
        ps.write(data.getBytes("UTF-8"));
 


再说字符流,要输出中国,需要设置response.setCharacterEncoding("UTF-8");

               //这句话的意思,是让浏览器用utf8来解析返回的数据
        response.setHeader("Content-type", "text/html;charset=UTF-8");
        //这句话的意思,是告诉servlet用UTF-8转码,而不是用默认的ISO8859
        response.setCharacterEncoding("UTF-8");
        String data = "中国";
        PrintWriter pw = response.getWriter();
        pw.write(data);

经验:1,如果中文返回出现??字符,这表明没有加response.setCharacterEncoding("UTF-8");这句话。

            2,如果返回的中文是“烇湫”这种乱码,说明浏览器的解析问题,应该检查下是否忘加response.setHeader("Content-type", "text/html;charset=UTF-8");这句话。

如果上面都解决不了,请看更详细的说明

http://blog.csdn.net/kontrol/article/details/7767983

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaWeb中,可以通过编写过滤器解决post请求方式中文乱码问题。具体步骤如下: 1. 创建一个过滤器类,实现javax.servlet.Filter接口。 2. 在过滤器类中重写doFilter方法。 3. 在doFilter方法中获取请求的编码方式,并将请求的数据按照该编码方式进行解码。 4. 在doFilter方法中修改请求的编码方式为UTF-8,并将修改后的请求传递给下一个过滤器或Servlet进行处理。 具体代码如下: ```java import javax.servlet.*; import javax.servlet.annotation.WebFilter; import javax.servlet.http.HttpServletRequest; import java.io.IOException; @WebFilter(filterName = "EncodingFilter", urlPatterns = "/*") public class EncodingFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { HttpServletRequest request = (HttpServletRequest) servletRequest; // 获取请求的编码方式 String encoding = request.getCharacterEncoding(); if (encoding == null) { encoding = "UTF-8"; // 默认编码方式为UTF-8 } // 将请求的数据按照指定编码方式进行解码 servletRequest.setCharacterEncoding(encoding); // 修改请求的编码方式为UTF-8 servletResponse.setContentType("text/html;charset=UTF-8"); filterChain.doFilter(servletRequest, servletResponse); } @Override public void destroy() { } } ``` 在上述代码中,我们使用@WebFilter注解来指定该类为过滤器,并且设置了过滤的urlPatterns为"/*",表示对所有请求进行过滤。 在doFilter方法中,我们首先获取请求的编码方式,并将请求的数据按照该编码方式进行解码。然后,我们将请求的编码方式修改为UTF-8,并将修改后的请求传递给下一个过滤器或Servlet进行处理。 需要注意的是,如果你使用了Spring框架,则可以通过在配置文件中添加如下配置来解决中文乱码问题: ```xml <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 在上述配置中,我们使用了Spring框架提供的CharacterEncodingFilter过滤器来解决中文乱码问题。可以通过在配置文件中添加该过滤器来自动解决中文乱码问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值