当前位置:首页 > 全部子站 > IT > 思科认证

solaris上开发J2EE应用中文问题的解决

来源:长理培训发布时间:2017-12-23 16:31:14

 百度广告

关于JSP和J2EE的中文问题和处理方法,网上已经有很多文章。一般在中文内核的操作系统(如中文NT,windows2000)上,该问题不是很突出,而在其他一些系统(如linux,solaris)中就比较明显了。近日在solaris上开发一个J2EE的应用系统,环境是solaris 2.7+minij2ee+mysql。系统在windows和linux下均没有出现中文处理的问题,但部署到solaris上面后所有中文显示为?。 

在浏览器中输入foo.jsp?i=中文,结果显示为??。如果将byte b=str.getBytes();换成上面注释掉的byte b=str.getBytes("iso-8859-1");,则正常显示出"中文"二字。查阅了mysql JDBC的驱动程序,问题相同。

  考虑解决的方法有两个,一个是修改JDBC驱动程序,另一个是将汉字编码成7位,从实现方便的角度选择了后者。不过后者的缺点是字符串长度增加,并且无法直接通过sql工具来修改数据库了。网上有一种汉字编码的方法,是将汉字高位去1,英文则补一个0表示。这种方法有缺陷,因为特定的汉字编码后会出现"'"等SQL语句中有歧义的字符,导致sql失败。我摘取了minij2ee中uniString的编码方法,该方法将字节表示为其16进制编码,下面是源代码: 


byte bytes=m_enc.compareTo("")==0?m_str.getBytes():m_str.getBytes(m_enc);

for(int i =0;i

return sb.toString(); 
catch(java.io.UnsupportedEncodingException e) 
throw new RuntimeException("Unsupported encoding type."); 
}

public void decode(String encodestr) 
StringBuffer sb=new StringBuffer(); 

while(i!=encodestr.length()) 
sb.append((char)Integer.parseInt(encodestr.substring(i,i+2),16)); 
}

m_str=new uniString(sb.toString(),"iso-8859-1").cvt(m_enc); 
使用编码后,问题解决。

  另外提一下,minij2ee最新版本中提供了一个uniString类,解决了在所有操作系统上的中文问题。使用uniString对象,无需关心字符串本身编码,使用时只要调用函数来获得需要的编码即可,如在jsp里调用uniString.gb()即可以以gb2312输出字符串,在数据库存储时调用uniString.iso()即可以以iso-8859-1编码输出字符串,无论在中文内核还是英文内核的操作系统上均通用

责编:罗莉

发表评论(共0条评论)
请自觉遵守互联网相关政策法规,评论内容只代表网友观点,发表审核后显示!

国家电网校园招聘考试直播课程通关班

  • 讲师:刘萍萍 / 谢楠
  • 课时:160h
  • 价格 4580

特色双名师解密新课程高频考点,送国家电网教材讲义,助力一次通关

配套通关班送国网在线题库一套

课程专业名称
讲师
课时
查看课程

国家电网招聘考试录播视频课程

  • 讲师:崔莹莹 / 刘萍萍
  • 课时:180h
  • 价格 3580

特色解密新课程高频考点,免费学习,助力一次通关

配套全套国网视频课程免费学习

课程专业名称
讲师
课时
查看课程
在线题库
面授课程更多>>
图书商城更多>>
在线报名
  • 报考专业:
    *(必填)
  • 姓名:
    *(必填)
  • 手机号码:
    *(必填)
返回顶部