全局编码过滤器--encodingFilter

本文介绍了一个全局编码过滤器的设计与实现,通过自定义的过滤器解决了HTTP请求中可能出现的字符编码问题。该过滤器能够确保所有传入的请求参数被正确地解码为UTF-8格式,并且提供了一个装饰器类来增强HttpServletRequest的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

全局编码过滤器–encodingFilter

//编码过滤器
public class EncodingFilter implements Filter {

    public void init(FilterConfig filterConfig) throws ServletException {

    }

    public void doFilter(ServletRequest req, ServletResponse resp,
            FilterChain chain) throws IOException, ServletException {
        // 1.将request,response强制转换成Http协议下使用request,与response
        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) resp;

        // 2.操作--将编码问题解决
        // request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");

        // 1.得到一个request装饰后的对象.
        HttpServletRequest myreq=new MyRequest(request);
        // 3.放行
        chain.doFilter(myreq, response);
    }

    public void destroy() {

    }

}

// 这个就是我们对request进行装饰的类
class MyRequest extends HttpServletRequestWrapper {

    private HttpServletRequest request;// 是用于接收外部传递的原始的request

    public MyRequest(HttpServletRequest request) {
        super(request); // 是因为父类没有无参数构造
        this.request = request;
    }

    @Override
    public String getParameter(String name) {

        if (name != null) {
            String[] st = (String[]) getParameterMap().get(name);
            if (st != null && st.length > 0) {
                return st[0];
            }
        }
        return null;
    }

    @Override
    public String[] getParameterValues(String name) {
        if (name != null) {

            return (String[]) getParameterMap().get(name);
        }
        return null;
    }

    private boolean flag = true;

    @Override
    public Map getParameterMap() {
        // 1.得到原始的map集合
        Map<String, String[]> map = request.getParameterMap();// 乱码

        if (flag) {
            // 2.将map集合中的String[]得到,解决每一个元素的乱码问题.
            for (String key : map.keySet()) {

                String[] st = map.get(key); // 得到每一个数组

                for (int i = 0; i < st.length; i++) {

                    try {
                        st[i] = new String(st[i].getBytes("iso8859-1"), "utf-8");
                    } catch (UnsupportedEncodingException e) {
                        e.printStackTrace();
                    }
                }

            }
            flag = false;
        }
        return map;

    }
### 如何在 IntelliJ IDEA 中配置 Tomcat 使用 UTF-8 编码 为了确保 Tomcat 在 IntelliJ IDEA 中使用 UTF-8 编码,可以按照以下方法进行配置: #### 修改 `catalina.sh` 或 `catalina.bat` 对于 Linux 和 macOS 用户,编辑位于 `$CATALINA_HOME/bin/catalina.sh` 文件;对于 Windows 用户,则应修改 `%CATALINA_HOME%\bin\catalina.bat` 文件。在这两个文件的最后一行添加 `-Dfile.encoding=UTF-Dfile.encoding=UTF-8" ``` 此操作会强制 JVM 启动时采用指定字符集作为默认编码方式。 #### 配置服务器启动参数 通过 IntelliJ IDEA 的运行/调试配置来调整 Tomcat 启动选项。进入 **Run -> Edit Configurations...**, 选择对应的 Tomcat Server 条目,在 VM options 字段内输入如下内容: ```plaintext -Dfile.encoding=UTF-8 ``` 这同样是为了让 Java 虚拟机以 UTF-8 方式处理字符串数据流[^2]。 #### 设置 Web 应用程序响应头 如果应用程序是基于 Servlet 技术构建的, 可考虑在 web.xml 文件中加入全局过滤器定义,用于设置 HTTP 响应头部信息中的 Content-Type 属性值为 text/html;charset=utf-8 : ```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> ``` 上述 XML 片段展示了如何利用 Spring Framework 提供的一个简单实用工具类 CharacterEncodingFilter 实现自动转换请求和响应体到所需编码格式的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值