servlet过滤器之EncodingFilter

本文介绍了一种解决从JSP页面提交的数据在Oracle数据库中出现乱码的方法。通过配置网页编码、Tomcat服务器参数及使用过滤器等方式,最终实现了正确编码。

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

在Action中得到从JSP页面中的数据 然后插入到oracle中却发现是乱码,我按着以下方式解决。

首先:

<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>


发现还是乱码,然后在<head>里设置

<meta http-equiv="content-type" content="text/html; charset=GBK">


还是不行,接着在tomcat里 server.xml

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


本来是可以在servlet里加入

request.setCharacterEncoding();


但没有servlet 也不知道如何在struts里的action中怎么设置编码。

最后想到了过滤器,还是用过滤器吧。

首先编写一个类实现Filter接口

package com.itmyhome.drp.filter; import java.io.*; import javax.servlet.*; public class EncodingFilter implements Filter { private String charSet; public void init(FilterConfig config) throws ServletException { // 接收初始化的参数 this.charSet = config.getInitParameter("charset"); } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { request.setCharacterEncoding(this.charSet); //继续执行 chain.doFilter(request, response); } public void destroy() { } }


在web.xml中配置<filter>和<filter-mapping>

<filter> <filter-name>encoding</filter-name> <filter-class>com.itmyhome.drp.filter.EncodingFilter</filter-class> <init-param> <param-name>charset</param-name> <param-value>GBK</param-value> </init-param> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值