六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 254|回复: 0

遗留系统中的RUBY中文解决方案

[复制链接]

升级  30%

3

主题

3

主题

3

主题

童生

Rank: 1

积分
15
 楼主| 发表于 2013-2-7 13:23:55 | 显示全部楼层 |阅读模式
看了一些朋友关于ROR中文问题的解决方法,受益匪浅;不过我的工作在一个遗留系统中,比如mysql的数据表全是latin的,sigh~``
下面的方法有点另类,并不推荐,仅作权宜之计。若众高手有更好的方法,可以一起讨论!当然除了把所有文件都改成UTF-8。
环境相关信息

       
  • 操作系统Suse Linux,默认编码为en_US   
  • Ruby 1.8.2,rails 1.2   
  • Mysql 3.x,数据表编码均为latin-1
问题一、Ruby脚本

$ruby -e "puts '诺基亚'"
执行失败,“-e:1: Invalid char `\273' in expression”
原因是ruby默认使用的KCODE是UTF-8,解决方法,使用-KN,将KCODE设置为NONE,那么:
$ruby -Kn -e "puts '诺基亚'"
问题二、Rails和数据库

在rails_home/app/controller/application.rb中添加filter:

  before_filter :set_charset
  def set_charset
    headers["Content-Type"]="text/html;charset=gbk"
  end
在rails_home/config/environment.rb中添加KCODE设置

$KCODE="none"
在众rhtml中的head标签里加入编码设置

注意事项

 还是上面的例子
$ruby -KN -e "puts '诺基亚'[0..1]"
这里会打印一个乱麻,因为这里还是使用单字节进行处理的
$ruby -KN -e "puts '诺基亚'[0..2]"
可以打印“诺”字,若要避免这种错误出现,ruby提供了一个安全的方式,建议使用:
$ruby -KN -e "puts '诺基亚'.chars[0..1]"
<meta http-equiv="content-type" content="text/html;charset=gbk">
Well done!

至此,我系统里的中文问题基本解决
 
 
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表