我写了一个Ruby脚本,试图连接到Heroku上托管的Postgres数据库。
如果我使用硬编码密码,或者使用gets
加载密码,一切正常。
但是,如果我使用IO.noecho
加载密码,则会出现以下异常:
storing.rb:11:in `initialize': FATAL: password authentication failed for user "***" (PG::ConnectionBad)
FATAL: no pg_hba.conf entry for host "****", user "***", database "***", SSL off
from storing.rb:11:in `new'
from storing.rb:11:in `create_conn'
from fetch_currencies.rb:11:in `<main>'
这是我的代码:
def create_conn(password)
conn = PGconn.connect(
:host => '***',
:port => 5432,
:dbname => '***',
:user => '***',
:password => password)
return conn
end
puts 'Postgres DB password:'
pass = STDIN.noecho(&:gets)
conn = create_conn(pass)
我在加载密码后尝试打印密码,并检查密码是否为字符串,一切似乎都没问题。可能是什么问题?
答案 0 :(得分:2)
问题当然是我没有chomp
输入,所以我猜终止的新行字符也作为密码的一部分传递。
正确的方法是
pass = STDIN.noecho(&:gets).chomp