解决数据库乱码问题的方法

1)JSP页面中显示中文乱码

     在JSP文件中使用page命令指定响应结果的MIME类型,如<%@ page language="java" contentType="text/html;charset=gb2312" %>


2)POST处理
servlet中
   response.setContentType("text/html;charset=utf-8");  //写在response.getWriter()之前
   request.setCharacterEncoding("utf-8");  //写在request.getParameter()之前

contentType -- 指定的是JSP页最终 Browser(客户端)所见到的网页内容的编码.
pageEncoding -- 指定JSP编写时所用的编码


3)表单提交乱码   

     表单提交时(post和Get方法),使用request.getParameter方法得到乱码,这是因为tomcat处理提交的参数时默认的是iso-8859-1,表单提交get和post处理乱码问题不同,

下面分别说明。

(1)POST处理
    对post提交的表单通过编写一个过滤器的方法来解决,过滤器在用户提交的数据被处理之前被调用,可以在这里改变参数的编码方式,过滤器的代码如下:

Java代码
package example.util;         
    public class SetCharacterEncodingFilter implements Filter {  
      
       protected String encoding = null;         
       protected FilterConfig filterConfig = null;  
      
       public void destroy() {         
        this.encoding = null;  
        this.filterConfig = null;         
     }  
      
     public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {  
    
       if (request.getCharacterEncoding() == null) {  
           request.setCharacterEncoding(encoding);  
        }  
       } 
      // Pass control on to the next filter  
      chain.doFilter(request, response);         
     }  
    public void init(FilterConfig filterConfig) throws ServletException {  
      
      this.filterConfig = filterConfig;  
      this.encoding = filterConfig.getInitParameter("encoding");    
     }  
    } 

 

web.xml添加配置:
<filter>
    <filter-name>Encoding</filter-name>
    <filter-class>example.util.SetCharacterEncodingFilter</filter-class>

    <init-param>
 <param-name>encoding</param-name>
    <param-value>gbk</param-value>
        <!--gbk或者gb2312或者utf-8-->
    </init-param>
</filter>
<filter-mapping> 
    <filter-name>Encoding</filter-name> 
    <servlet-name>/*</servlet-name> 
</filter-mapping> 

(2) Get方法的处理
 tomcat对post和get的处理方法不一样,所以过滤器不能解决get的乱码问题,它需要在其他地方设置。
 打开<tomcat_home>/conf目录下server.xml文件,找到对8080端口进行服务的Connector组件的设置部分,给这个组件添加一个属性:URIEncoding="GBK"。修改后的Connector设

置为:
 

Java代码
<Connector port="8080" maxHttpHeaderSize="8192"
               maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
               enableLookups="false" redirectPort="8443" acceptCount="100"
               connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="GBK" />
  * 注意修改后重新启动tomcat才能起作用。

 

4)GET 方式的乱码
String name1=new String(name.getBytes("iso8859-1"),"utf-8");

 


5)数据库
mysql>status;  //可查看出当前数据库的编码
mysql>alter database 数据库名 character set utf8;

在myeclipse中修改数据库的显示
Connection URL=jdbc:mysql://localhost:3306/database_name?useUnicode=true&characterEncoding=utf8

 


6)
一个不需要修改任何 Tomcat 配置文件的完美解决中文问题的过滤器的代码:
index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
 <title>表单测试页面</title>
  </head>
  <body>
        <form action="action.jsp">
 GET 方式: <input type=text name="name" value="GET 中文">
 <input type=submit>
        </form>
 <form action="action.jsp" method="POST">
 POST 方式: <input type=text name="name" value="POST 中文">
 <input type=submit>
  </form>
  </body>
</html>
和普通的表单没有任何区别.


然后就是表单提交页面 action.jsp:
<%@ page language="java" pageEncoding="GBK"%>
<html>
<body>
参数: <%=request.getParameter("name") %> <br>
</body>
</html>


接着是过滤器的配置文件 web.xml (用 2.5 版本也可以):
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="
http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="
http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<filter>
<filter-name>TomcatFormFilter</filter-name>
<filter-class>filters.TomcatFormFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>TomcatFormFilter</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>


最后最关键的就是我们的过滤器代码了, 对 GET 方式使用请求包装器, 而 POST 方式则用 setCharacterEncoding():
package filters;
public class TomcatFormFilter implements Filter {
/**
* Request.java
* 对 HttpServletRequestWrapper 进行扩充, 不影响原来的功能并能提供所有的 HttpServletRequest
* 接口中的功能. 它可以统一的对 Tomcat 默认设置下的中文问题进行解决而只需要用新的 Request 对象替换页面中的
* request 对象即可.
*/
class Request extends HttpServletRequestWrapper
{
public Request(HttpServletRequest request) {
super(request);
}
/**
* 转换由表单读取的数据的内码.
* 从 ISO 字符转到 GBK.
*/
public String toChi(String input) {
try {
byte[] bytes = input.getBytes("ISO8859-1");
return new String(bytes, "GBK");
}
catch (Exception ex) {
}
return null;
}
/**
* Return the HttpServletRequest holded by this object.
*/
private HttpServletRequest getHttpServletRequest()
{
return (HttpServletRequest)super.getRequest();
}
/**
* 读取参数 -- 修正了中文问题.
*/
public String getParameter(String name)
{
return toChi(getHttpServletRequest().getParameter(name));
}
/**
* 读取参数列表 - 修正了中文问题.
*/
public String[] getParameterValues(String name)
{
String values[] = getHttpServletRequest().getParameterValues(name);
if (values != null) {
for (int i = 0; i < values.length; i++) {
values[i] = toChi(values[i]);
}
}
return values;
}
}
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpreq = (HttpServletRequest)request;

if(httpreq.getMethod().equals("POST")) {
request.setCharacterEncoding("GBK");
} else {
request = new Request(httpreq);
}
chain.doFilter(request, response);
}
public void init(FilterConfig filterConfig) throws ServletException {
}
}

 

 

 

 

 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值