现在的位置: 首页 > 综合 > 正文

关于Servlet和JNI中汉字编码问题的解决

2014年11月22日 ⁄ 综合 ⁄ 共 722字 ⁄ 字号 评论关闭

1、网页间解决汉字编码问题:http://dev.csdn.net/Develop/article/21/21757.shtm
  当网页提交时URL中汉字以GB2312编码,则网页文件要保存成ANSI编码的文件,否则会以UTF-8编码传送。web容器默认编码是iso-8859-1,
  一个汉字占用两个字节,而在utf-8中一个汉字占用三个字节。所以在数据传递过程中,必须手动设定容器编码格式,否则会出现字符位丢失
  的情况。即3个字节变为两个字节,自然会变成乱码。

  若URL=GB2312,response.setContentType(text/html;charset=GB2312)(UTF-8也行);则servlet中word.getBytes("iso-8859-1"),"GB2312")即可
  若URL=UTF-8,response.setContentType(text/html;charset=UTF-8)(GB2312也行);则servlet中word.getBytes("iso-8859-1"),"UTF-8")即可
 2、JNI的汉字编码问题:http://blog.csdn.net/dztc/archive/2005/12/22/559072.aspx
  从C++返回的中文若不作处理,如 char str2[]="我们,we are the world!/n"; jstr=env->NewStringUTF(str2); return jstr;则在Java接收里
  处理如new string(recv.getBytes("iso-8859-1"),"GB2312"),若在C++中已作处理,则不必在Java中转换 

抱歉!评论已关闭.