JAVA处理汉字

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" %>也能正确显示中文。

 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值