请问在JSP中,向sql2000中插入数据的中文化问题

Yang_Sun 2001-06-30 07:27:52
我现在需要向MS SQLServer2000中,通过JSP提交的形式,提交数据给sqlServer服务器。我是通过jdbcodbc桥形式连接的,但是插入英文毫无问题,中文则为问号。如果在JavaBean测试中,提交中文也没有问题,我把源码贴上,请高手指教,如何修改,最好能有简单的代码示例,多谢。
提交网页:
<html>
<head>
<title>Untitled Document</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body bgcolor="#FFFFFF" text="#000000">
<p>测试向SQL数据库中回填数据</p>
<form name="form1" method="post" action="Result.jsp">
<table width="48%" border="1" align="center">
<tr>
<td width="26%">
<div align="left">用户名字</div>
</td>
<td width="74%">
<div align="left">
<input type="text" name="username">
</div>
</td>
</tr>
<tr>
<td width="26%">用户住址</td>
<td width="74%">
<div align="left">
<input type="text" name="address">
</div>
</td>
</tr>
</table>
<p align="center">
<input type="submit" name="Submit" value="Submit">
</p>
</form>
<p>  </p>
</body>
</html>

JavaBean源码:
package mytest;

/**
* Title: ContactSQLServer
* Description: 此项目主要用于测试向SQL Server数据库中回填数据时,产生的中文乱码问题,测试环境为MS SQLServer2000
* Copyright: Copyright (c) 2001
* Company: Tsinghua University
* @author Sunny
* @version 1.0
*/

import java.sql.*;
import java.util.Properties;
public class ContactSQLBean {
/**
* 此Bean通过向SQLServer2000中,测试用数据库TestDB写入
* 两个字段(username, address)写入数据,测试回填的中文
* 化问题
*/

private String username;
private String address;
Connection conn;
PreparedStatement prepStmt;

public void setusername(String username) {
this.username = username;
}

public void setaddress(String address) {
this.address = address;
}

public static void main(String args[]) {
ContactSQLBean test = new ContactSQLBean();
test.insertUserInfo("孙阳", "清华大学");
test.closeDB();
}

/**
* 在构造函数中对conn对象进行初始化
*/
public ContactSQLBean() {
String url = "jdbc:odbc:TestDB";
Properties props = new Properties();
props.setProperty("username", "sa");
props.setProperty("password", "");

try{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
conn = DriverManager.getConnection(url, props);
conn.commit();
}
catch(Exception e) {
System.out.println("Connect Error " + e.getMessage());
}
}

/**
* 中断数据库连接
*/
public void closeDB() {
try{
conn.close();
}catch(Exception e) {
e.printStackTrace();
}
}

/**
* 向tab_user_info表中插入记录
*/
public boolean insertUserInfo(String username, String address){
String insertString ="insert into sunny.testdb.dbo.tab_user_info " +
"values(?, ?)";
String gbusername; //编码后的username
String gbaddress; //编码后的address

try {
gbusername = new String(username.getBytes("GB2312"), "ISO8859_1");
prepStmt = conn.prepareStatement(insertString);
//对字符串编码与否,在数据库中都是一样的乱码
prepStmt.setString(1, gbusername);
prepStmt.setString(2, address);
prepStmt.executeUpdate();
conn.commit();
return true;
}catch (Exception e) {
e.printStackTrace();
System.out.println(e.getMessage());
return false;
}
}
}

JSP网页为:
<%@ page language = "java" %>
<%@ page contentType = "text/html;charset=gb2312" %>
<jsp:useBean id = "SqlBean" scope = "session" class = "mytest.ContactSQLBean" />
<%! String username, address; %>
<%
username = new String(request.getParameter("username").getBytes("GB2312"),
"ISO8859_1");
address = new String(request.getParameter("address").getBytes("GB2312"),
"ISO8859_1");
%>
<HTML>
<HEAD>
<TITLE>
Result
</TITLE>
</HEAD>
<BODY>
<H1>
<%
if (SqlBean.insertUserInfo(username, address) == true){
out.print("修改数据成功");
}else {
out.print("修改数据不成功");
}
%>
</H1>
</BODY>
</HTML>

...全文
127 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
BrentIvan 2001-06-30
  • 打赏
  • 举报
回复
发信人: hht (Duke), 信区: Java
标 题: JDK1.2关于JDBC中文问题的解决方案&Re yzhang
发信站: 网易虚拟社区 (Mon Jan 11 13:29:43 1999), 转信

忙了几天,终于对JDK1.2的JDBC中文问题有了初步的了解,虽然还有问题存在,但我
想大家可能都着急了吧?:)所以就把我的初步想法先贴出来,欢迎大家补充.
JDK1.2的中文问题主要是由于引入了Unicode引起的(其实在1.1版本中就有了),U
nicode的字符由16bit构成,关于Unicode更详细的信息有兴趣者可以到www.unico
de.org查阅,在1.0版本中,一个中文是由两个char(8bit)组成的,而1.1以上版本中
是由一个char(16bit)组成的.这一点大家可以用System.out.println(s.length(
))语句来证实,其中s为中文字串.
现在来说说解决办法,首先声明这些结果只是在我的环境里测试通过,如果在各位
的环境里有问题,请务必告知.
我的环境是JDK1.2+Win95+Sybase JDBC Driver(PowerJ2.5附带)+Oracle JDBC D
river(Oracle8.0.3附带).
我的第一个体会是用JDBC-ODBC桥接访问数据库中文输入有问题,我还没解决,我用
的JDBCODBC Driver是JDK1.2自带的.
第二个体会是用JDBC直接联数据库,这时可能有两种情况:
1,中文输入没问题(Oracle8),即可以在SQL语句中直接写中文,如:
statement.executeUpdate("inser into tablename values("测试",....)
2,中文输入有问题(Sybase11),看错误可知是Unicode转换引起的,解决办法是将U
nicode转换为ASCII形式,即一个汉字拆成两个char,用到两个类ByteToCharConve
rter和CharToByteConverter,在sun.io.*中,可以在JDK home\jre\lib\i18n.jar
中找到,没有文档,我也实在网上找到用法的.
在输入时,用ChineseStringToAscii转换为ASCII码字串,查询时用AsciiToChines
eString转换为Unicode字串.源代码如下:
public static String AsciiToChineseString(String s) {
char[] orig = s.toCharArray();
byte[] dest = new byte[orig.length];
for (int i=0;i<orig.length;i++)
dest[i] = (byte)(orig[i]&0xFF);
try {
ByteToCharConverter toChar = ByteToCharConverter.getConverter("g
b2312");
return new String(toChar.convertAll(dest));
}
catch (Exception e) {
System.out.println(e);
return s;
}
}

public static String ChineseStringToAscii(String s) {
try {
CharToByteConverter toByte = CharToByteConverter.getConverter("g
b2312");
byte[] orig = toByte.convertAll(s.toCharArray());
char[] dest = new char[orig.length];
for (int i=0;i<orig.length;i++)
dest[i] = (char)(orig[i] & 0xFF);
return new String(dest);
}
catch (Exception e) {
System.out.println(e);
return s;
}
}
主程序片断如下:
try{
Statement stmt;
Class.forName("com.sybase.jdbc.SybDriver");
Connection conn =DriverManager.getConnection ("jdbc:sybase:Tds:202.9
7.228.249:5000/todo","sa","");
stmt = conn.createStatement ();
String s="何海涛";
s=ChineseStringToAscii(s);
stmt.executeUpdate ("insert into russia values('"+s+"',1,1,'"+s+
"')");
}catch(Exception e){
System.out.println(e);
}
在读数据时用String s=AsciiToChineseString(rs.getString(1))
--------------------
因为手头只能对这两种数据库进行测试,所以对别的数据库可能出现的情况不能保
证.不过我估计基本是上面这两种情况.另外,用JDK1.2有的公司提供的Driver也升
级了,比如Sybase原来的Driver就不好使.原理就是这样,在实际操作中要靠自己摸
索了.上面两个方法参考了台湾某BBS的一篇文章.
另外,yzhang不知你要的是什么版本,你可以在jconnect软件安装的目录下找JDBC
Driver包,可能的格式是zip或jar,把他拷出来就行了.我的就是从PowerJ中拷出
来的


81,092

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧