1.在url附带中文参数,可以直接读取。
例如:
<%= request.getParameter("showword")%>
2 与数据库有关的各种sql操作
这里使用的Access没有发生问题。
JDBC中文处理
一,取中文
用JDBC执行SELECT语句从SERVER取数据(中文)后,将数据用APPEND方法加到TEXT AREA(TA),不能正确显示。但加到LIST中时,则大部分汉字可正确显示。
处理:将数据按“ISO-8859-1”格式转为字节数组,再按系统缺省编码格式(default character encoding)转为STRING,即可在TA和LIST中正确显示。
程序段如下:
dbstr2 = results.getString(1);
dbbyte1 = dbstr2.getBytes("iso-8859-1");
dbstr1 = new String(dbbyte1);
二,写中文到DB
处理方式与以上相逆,先将SQL语句按DEFAULT CHARACTER ENCODING转为字节数组,再按ISO-8859-1转为STRING,然后送执行,则中文信息可正确写入DB。
sqlstmt = tf_input.getText();
dbbyte1 = sqlstmt.getBytes();
sqlstmt = new String(dbbyte1,"iso-8859-1");
_stmt = _con.createStatement();
_stmt.executeUpdate(sqlstmt);
取DB2的数据:
例句 select * from test where title='谁是傻瓜'.在jdbc-odbc驱动下连db2,不管是原句还是对sql语句进行编码后都死活通不过。换了ibm的jdbc直接驱动后,对sql语句编码后程序可以通过。
我的解决方法:
对取出的数据进行编码:
byte a[]=s.getBytes("GBK");//不是ISO-8859-1
s=new String(a);
处理汉字的公用函数
public String TransString(String s)
{
if(s==null) s="";
try
{
byte a[]=s.getBytes("GBK");
s=new String(a);
}
catch(Exception e)
{
s="出错:"+e.getMessage();
}
return s;
}
3 读取HTML form表单中递交的中文值
在jswdk中需要加以编码,较为简洁的写法如:
String name1=new String(request.getParameter("user_id").getBytes("ISO8859_1"));
另外,在jdk1.3的支持下,不需要加入<%@ page contentType="text/html;charset=gb2312" %>
而在jdk1.2.2下面,即使2种方法同时运用也很不稳定。
而在resin平台,情况较好。只要在页面第一行加入:
<%@ page contentType="text/html;charset=gb2312" %>即可正确处理中文。如果再加编码则反而不对。
4 session中包含的中文
在jswdk中,奇怪的是如果从form中读出的值经过编码则可正确显示;但直接赋予中文值则不行。resin平台很好,同上。
5 对于对变量赋中文值后正确显示中文。
例如以下程序:
<%@ page contentType="text/html;charset=gb2312" %>
<html><head></head><body>
<%
String Hi="你好";
byte[] tmpbyte=Hi.getBytes("ISO8859_1");
Hi=new String(tmpbyte);
out.print(Hi);
%>
</body></html>
同样是jswdk1.0.1,以上的表示方法在jdk1.2.2中没有问题,但在jdk1.3下却无法显示。resin平台很好,同上,经过测试,只需要在<head>中补上<meta http-equiv="Content-Type" content="text/html; charset=gb2312">,而不需要<%@ page contentType="text/html;charset=gb2312" %>也能正确显示中文。