JSP的6种乱码解决方案「建议收藏」

JSP的6种乱码解决方案「建议收藏」JSP的6种乱码解决方案

大家好,又见面了,我是你们的朋友全栈君。

1.通过字节码组进行转换

        String num = request.getParameter("num");
        String name = new String(request.getParameter("name").getBytes("ISO-8859-1"), "utf-8");
        String type = new String(request.getParameter("type").getBytes("ISO-8859-1"), "utf-8");

2.查看jsp文件头是否设置了编码格式:

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

3.查看项目的编码格式:设置为UTF-8 :project–》properties:
在这里插入图片描述4.上面一般解决的是页面本身中文的乱码,如果还有问题,比如提交的表单乱码等问题,需要在请求头响应头设置编码:

//设置编码格式
req.setCharacterEncoding("UTF-8");
resp.setCharacterEncoding("UTF-8");

5.最后还没解决乱码的话,设置tomcat服务器编码格式,默认情况下,tomcat使用的的编码方式:iso8859-1,打开setting.xml文件(在tomcat文件夹conf中)
找到如下代码:

<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

这段代码规定了Tomcat监听HTTP请求的端口号等信息。
可以在这里添加一个属性:URIEncoding,将该属性值设置为UTF-8,即可让Tomcat(默认ISO-8859-1编码)以UTF-8的编码处理get请求。

<Connector port="8080"  protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8" />

6.JSP Filter(编码过滤器)

过滤器是一个实现了 javax.servlet.Filter 接口的 Java 类。javax.servlet.Filter 接口定义了三个方法:

public void init(FilterConfig filterConfig){
    web 应用程序启动时,web 服务器将创建Filter 的实例对象,并调用其init方法,读取web.xml配置,完成对象的初始化功能,从而为后续的用户请求作好拦截的准备工作(filter对象只会创建一次,init方法也只会执行一次)。开发人员通过init方法的参数,可获得代表当前filter配置信息的FilterConfig对象(见后文实例)。
}

public void doFilter (ServletRequest, ServletResponse, FilterChain){
    该方法完成实际的过滤操作,当客户端请求方法与过滤器设置匹配的URL时,Servlet容器将先调用过滤器的doFilter方法。FilterChain用户访问后续过滤器。
}

public void destroy(){
    Servlet容器在销毁过滤器实例前调用该方法,在该方法中释放Servlet过滤器占用的资源。
}

在src/main/java里添加继承Filter类的TestFilter过滤器类。
TestFilter.java里的代码:

package com.wb.filter;

import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.Map.Entry;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
public class TestFilter implements Filter { 
   
    @Override
    public void destroy() { 
   
        System.out.println("过滤器销毁.......");
    }
    @Override
    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain) throws IOException, ServletException { 
   
        System.out.println("进行过滤器开发.......");
        // 只要在这里加 先解决post请求乱码
        request.setCharacterEncoding("utf-8");// 请求
        response.setCharacterEncoding("utf-8");// 响应
        response.setContentType("text/html;charset=utf-8");// 响应
        // get提交乱码处理
        chain.doFilter(new MyRequest((HttpServletRequest) request), response);

    }

    @Override
    public void init(FilterConfig filterConfig) throws ServletException { 
   
        System.out.println("过滤器初始化.......");

    }
    class MyRequest extends HttpServletRequestWrapper { 
   
        HttpServletRequest request;
        public MyRequest(HttpServletRequest request) { 
   
            super(request);
            this.request = request;
        }
        @Override
        public String getParameter(String name) { 
   
            String value = request.getParameter(name);
            // 先判断是否为空
            if (value == null) { 
   
                return null;
            }
            // 再判断提交方法
            if (!request.getMethod().equals("GET")) { 
   
                return value;
            }
            // get提交
            try { 
   
               value = new String(value.getBytes("iso8859-1"), "utf-8");
            } catch (UnsupportedEncodingException e) { 
   
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            return value;
        }
        @Override
        public String[] getParameterValues(String name) { 
   
            String[] oldValues = request.getParameterValues(name);
            String[] newValues = null;
            if (oldValues != null) { 
   
                newValues = new String[oldValues.length];
                if (!request.getMethod().equals("GET")) { 
   
                    return oldValues;
                }
                if (newValues != null) { 
   
                    try { 
   
                        for (int i = 0; i < oldValues.length; i++) { 
   
                            String value = oldValues[i];
                            value = new String(value.getBytes("iso8859-1"),
                                    "utf-8");
                            newValues[i] = value;
                        }
                    } catch (UnsupportedEncodingException e) { 
   
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
            }
            return newValues;
        }
        @Override
        public Map<String, String[]> getParameterMap() { 
   
            // 1.拿到客户端的值
            Map<String, String[]> oldMap = request.getParameterMap();
            // 2.新map
            Map<String, String[]> newMap = new HashMap<String, String[]>();
            // 3.拿出oldMap
            Set<Entry<String, String[]>> entrySet = oldMap.entrySet();
            for (Entry<String, String[]> entry : entrySet) { 
   
                // 4.获取键
                String key = entry.getKey();
                // 5.获取值
                String[] values = entry.getValue();
                // 新的数组和原数组一样大
                String[] newValues = new String[values.length];
                // 6.判断值是否为空
                if (values == null) { 
   
                    newMap.put(key, new String[] { 
   });// 初始化
                    continue;
                }
                // 7.取出values里面每一个值进行转码
                try { 
   
                    for (int i = 0; i < values.length; i++) { 
   
                        String value = values[i];
                        value = new String(value.getBytes("iso8859-1"), "utf-8");
                        // value = new String(value.getBytes("iso8859-1"),
                        // request.getCharacterEncoding());
                        newValues[i] = value;
                    }
                    newMap.put(key, newValues);
                } catch (UnsupportedEncodingException e) { 
   
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            return newMap;
        }
    }
}

在web.xml配置过滤器:

<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
  <!-- 定义Filter -->
	<filter>
		<filter-name>Set Character Encoding</filter-name>
		<filter-class>com.wb.filter.TestFilter</filter-class>
		<init-param>
			<param-name>encoding</param-name>
			<param-value>UTF-8</param-value>
		</init-param>
	</filter>
	<filter-mapping>
		<filter-name>Set Character Encoding</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>
</web-app>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106674.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pytorch下载CIFAR10数据集[通俗易懂]

    pytorch下载CIFAR10数据集[通俗易懂]importtorchfromtorchvisionimportdatasetsfromtorchvisionimporttransformsfromtorch.utils.dataimportDataLoaderdefmain():batchsz=32cifar_train=datasets.CIFAR10(‘cifar’,True,transform=transforms.Compose([transforms.Re

    2022年6月22日
    170
  • shift后门结论_连续五次shift

    shift后门结论_连续五次shift经常会看到一些服务器被入侵后,入侵者会留下一些各式各样的shift后门,五花八门的,各位网络管理员也看看自己的服务器的setch.exe是否被人替换了。这个直接5次shift后进入分区这个比较巧妙了,正常的最后那个按钮是灰色的,前两个是不可点击的,这个恰恰想法,点击后,会弹出一个cmd窗口。这个是比较常见的需要输…

    2022年9月18日
    0
  • 深度学习图像标注工具汇总

    深度学习图像标注工具汇总对于监督学习算法而言,数据决定了任务的上限,而算法只是在不断逼近这个上限。世界上最遥远的距离就是我们用同一个模型,但是却有不同的任务。

    2022年6月1日
    33
  • pycharm中安装opencv2_starter安装报错

    pycharm中安装opencv2_starter安装报错图像处理新人,想练习一下opencv库在PyCharm终端pipinstallopencv-python显示安装失败!!!查看了一下竟然是因为BOSEInterpreter是Anaconda去官网上下载了个python解释器就好了!!!给自己提个醒吧!

    2022年8月25日
    3
  • VLDB论文解读:阿里云超大规模实时分析型数据库AnalyticDB「建议收藏」

    VLDB论文解读:阿里云超大规模实时分析型数据库AnalyticDB「建议收藏」1、背景随着数据量的快速增长,越来越多的企业迎来业务数据化时代,数据成为了最重要的生产资料和业务升级依据。伴随着业务对海量数据实时分析的需求越来越多,数据分析技术这两年也迎来了一些新的挑战和变革:在线化和高可用、离线和在线的边界越来越模糊,一切数据皆服务化、一切分析皆在线化; 高并发低延时,越来越多的数据系统直接服务终端客户,对系统的并发和处理延时提出了新的交互性挑战; 混合负载,一套实时分析系统既要支持数据加工处理,又要支持高并发低延时的交互式查询; 融合分析,随着对数据新的使用方式探索,需

    2022年9月17日
    0
  • 十大免费代理ip软件_国内静态ip代理软件

    十大免费代理ip软件_国内静态ip代理软件如今,随着网络的快速发展,很多的人对代理IP都已经有了很深入的了解,那么有很多的朋友在使用代理IP的时候也会遇到各种各样的问题,下面就带大家来详细了解下代理IP的使用技巧。1、直接使用代理IP打开Internet选项,通过对局域网的设置来选择LAN代理服务器,其次填写相对应的端口号以及ip地址,填写好之后就可以保存刷新浏览器IP就变更好了,使用这种方法能够解决网站的ip地址限制问题,适合效果补量的业务。2、代理IP的并发不宜过大在使用代理IP时,无论代理IP有没有并发的限制,单个的IP都不能过大.

    2022年4月20日
    900

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号