我得到了错误的incompatible character encodings: UTF-8 and ASCII-8BIT,当视图在数据库中找到一些字符,如:á,á,é等。
我的环境是:
我可以使用蟾蜍将这些字符保存在数据库中。
我试图用我的观点的第一行来写这个:
<% # encoding: utf-8 %>在enviroment.erb中
Encoding.default_external = Encoding::UTF_8
Encoding.default_internal = Encoding::UTF_8但没什么能解决这个。
拜托,谁能给点建议来解决这个问题。
谢谢。
发布于 2013-06-27 20:27:07
在文件boot.rb中,我添加了以下一行:
ENV['NLS_LANG'] = 'AMERICAN_AMERICA.UTF8'我解决了我的问题。
发布于 2013-05-24 14:39:02
我也有同样的问题,经过几个小时的猴子补丁搜索后,我解决了这个问题。
module ActiveSupport #:nodoc:
class SafeBuffer < String
def safe_concat(value)
value = force_utf8_encoding(value)
raise SafeConcatError unless html_safe?
original_concat(value)
end
def concat(value)
value = force_utf8_encoding(value)
if !html_safe? || value.html_safe?
super(value)
else
super(ERB::Util.h(value))
end
end
alias << concat
private
def force_utf8_encoding(value)
self.force_encoding('UTF-8').html_safe unless self.encoding.name == 'UTF-8'
value = (value).force_encoding('UTF-8').html_safe unless value.nil? || value.encoding.name == 'UTF-8'
value
end
end
endhttps://stackoverflow.com/questions/11478316
复制相似问题