Java 中文问题的解决 mysql, oracle, servlet, jsp

原创 2004年06月23日 14:22:00

在tomcat5中发现了以前处理tomcat4的方法不能适用于处理直接通过url提交的请求,上网找资料终于发现了最完美的解决办法,不用每个地方都转换了,而且无论get,和post都正常。写了个文档,贴出来希望跟我有同样问题的人不再像我一样痛苦一次:-)

上传文件有问题,只好直接贴了,难看点:-)

-------------------
Tomcat 5中文问题
author:kiss__sky@163.com
-------------------

问题描述:

1 表单提交的数据,用request.getParameter(“xxx”)返回的字符串为乱码或者??
2 直接通过url如http://localhost/a.jsp?name=中国,这样的get请求在服务端用request. getParameter(“name”)时返回的是乱码;按tomcat4的做法设置Filter也没有用或者用request.setCharacterEncoding("GBK");也不管用

原因:
1 tomcat的j2ee实现对表单提交即post方式提示时处理参数采用缺省的iso-8859-1来处理
2 tomcat对get方式提交的请求对query-string 处理时采用了和post方法不一样的处理方式。(与tomcat4不一样,所以设置setCharacterEncoding(“gbk”))不起作用。


解决办法:

首先所有的jsp文件都加上:
<%@ page contentType="text/html;charset=gb2312"%>

1 实现一个Filter.设置处理字符集为GBK。(在tomcat的webapps/servlet-examples目录有一个完整的例子。请参考web.xml和SetCharacterEncodingFilter的配置。)

1)只要把%TOMCAT安装目录%/ webapps/servlets-examples/WEB-INF/classes/filters/SetCharacterEncodingFilter.class文件拷到你的webapp目录/filters下,如果没有filters目录,就创建一个。
2)在你的web.xml里加入如下几行:


<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>filters.SetCharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>
</init-param>
</filter>

<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>


3)完成.

2 get方式的解决办法
1) 打开tomcat的server.xml文件,找到区块,加入如下一行:
URIEncoding=”GBK”
完整的应如下:


<Connector
port="80" maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
debug="0" connectionTimeout="20000"
disableUploadTimeout="true"
URIEncoding="GBK"
/>



2)重启tomcat,一切OK。

执行如下jsp页页测试是否成功


<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.util.*"%>

<%

String q=request.getParameter("q");
q = q == null? "没有值" : q;

%>


<HTML>
<HEAD><TITLE>新闻列表显示</TITLE>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<META http-equiv=pragma content=no-cache>
<body>
你提交了:
<%=q%>

<br>
<form action="tcnchar.jsp" method="post">
输入中文:<input type="text" name="q"><input type="submit" value="确定">
<br>
<a href="tcnchar.jsp?q=中国">通过get方式提交</a>

</form>
</BODY></HTML>



测试结果如果你输入文本框或者点超链都会显示:你提交了”中国”,说明成功!!!!!



特别感谢下面这篇帖子,帮我解决了中文问题.最后祝大家好运!!!
参考网址:

http://www.javaworld.com.tw/jute/post/view?bid=9&id=44042&sty=1&tpg=1&age=0

Java 中文问题一直困扰许多学习者。总结了下面的一些情况的解决方法。
希望对大家有帮助。

连接 Mysql Database Server:
-------------------------------------------------------------------------------
 mysql 不支持 unicode,所以比较麻烦。
 将 connectionString 设置成 encoding 为 gb2312
 String connectionString
 = "jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=gb2312";

测试代码:
       String str = "汉字";
       PreparedStatement pStmt = conn.prepareStatement("INSERT INTO test VALUES (?)");
       pStmt.setString(1,str);
       pStmt.executeUpdate();

数据库表格:
 create table test (
   name char(10)
 )


连接 Oracle Database Server
-------------------------------------------------------------------------------
 在把汉字字符串插入数据库前做如下转换操作:
 String(str.getBytes("ISO8859_1"),"gb2312")

测试代码:
       String str = "汉字";
       PreparedStatement pStmt = conn.prepareStatement("INSERT INTO test VALUES (?)");
       pStmt.setString(1,new String(str.getBytes("ISO8859_1"),"gb2312");
       pStmt.executeUpdate();


Servlet
-------------------------------------------------------------------------------
 在 Servlet 开头加上两句话:
 response.setContentType("text/html;charset=UTF-8");
 request.setCharacterEncoding("UTF-8");

JSP
-------------------------------------------------------------------------------
 在 JSP 开头加上:
 <%@ page contentType="text/html; charset=gb2312" %>

关于Servlet中前后台交互中文乱码问题的解决

在servlet前后台交互时,我们会经常遇到中文乱码的问题,以后是我总结的解决方式: 一、交互过程中,参数乱码的解决:    1.  如果请求方式是“get”: String user...
  • BeauXie
  • BeauXie
  • 2016年08月24日 14:55
  • 3264

JSP,servlet和数据库之间传值出现乱码的问题

最近困扰我很久的一个问题终于解决了,为他我头疼了好几天,问题是JSP通过servlet向数据库传值,查询显示在页面的时候出现了乱码,原先我数据库中有两行带有中文的数据,查询的时候倒是没有出现乱码,我d...
  • cxy782255346
  • cxy782255346
  • 2014年11月16日 16:10
  • 1772

JSP用过滤器解决request中文乱码问题

(1)客户端的数据一般是通过HTTP  GET/POST方式提交给服务器,在服务器端用request.getParameter() 读取参数时,很容易出现中文乱码现象。 (2)用过滤器解决requ...
  • u010870518
  • u010870518
  • 2014年09月10日 14:01
  • 2054

解决Servlet的乱码问题

解决servlet的乱码问题
  • canot
  • canot
  • 2016年01月09日 21:19
  • 6514

jsp数据提交至servlet中文乱码

【出现乱码的原因】         首先无论使用get方式提交,还是post方式提交,如果参数中包含中文,浏览器都会使用当前浏览器编码对其进行URL编码,然后服务器端再进行URL解码,如果浏览器...
  • u013795673
  • u013795673
  • 2016年08月24日 15:37
  • 2656

解决JSP中文乱码问题

原文:http://www.cnblogs.com/chengkai/articles/2171848.html 大家在JSP的开发过程中,经常出现中文乱码的问题,可能一至困扰着大家,现把J...
  • luoweifu
  • luoweifu
  • 2014年03月25日 23:46
  • 4069

JSP, Servlet常见面试题详解

JSP, Servlet常见面试题 1,J2EE是什么? 2EE是一套全然不同于传统应用开发的技术架构,包含许多组件,主要可简化且规范应用系统的开发与部署,进而提高可移植性、安全与再用价值。 2...
  • u011934553
  • u011934553
  • 2014年10月02日 10:16
  • 5572

java web中配置Filter解决jsp中文乱码问题

具体的做法:    建立一个实现 Filter 接口的类。这个类需要三个方法,分别是: doFilter 、 init 和 destroy 。 doFilter 方法包含主要的过滤代码, init 方...
  • yinxianluo
  • yinxianluo
  • 2014年11月22日 21:00
  • 1118

JSP+Servlet+oracle 的一个分页查询小应用

JSP+Servlet+oracle 的一个分页查询小应用 功能实现:1.编写1个简单jsp页面,提交表单提交一个人的名字到servlet控制器中。 2.编写一...
  • as18819281938
  • as18819281938
  • 2016年06月06日 15:45
  • 1511

JSP和Servlet面试题

1.讲下servlet的执行流程。 Servlet的执行流程也就是servlet的生命周期,当服务器启动的时候生命周期开始,然后通过init()《启动顺序根据web.xml里的startup-o...
  • t0404
  • t0404
  • 2016年07月12日 22:44
  • 8987
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java 中文问题的解决 mysql, oracle, servlet, jsp
举报原因:
原因补充:

(最多只允许输入30个字)