我编写了一个 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)
我尝试在加载密码后打印密码,并检查它是否是字符串,一切似乎都很好。可能是什么问题?
最佳答案
问题当然是我没有chomp
输入,所以我猜终止换行符也作为密码的一部分传递。
正确的做法是这样
pass = STDIN.noecho(&:gets).chomp
关于Ruby隐藏输入密码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19081307/