我正在编写一个小代码,它必须:
- 与 SFTP 连接
- 在 PostgreSQL 上执行命令(密码保护)
我愿意将密码用作纯文本。
目前我的代码是:
import pysftp
command = "... some SQL command"
sftp= pysftp.Connection('server_name', username='username', password='password')
sftp.execute("export PGPASSWORD='password_to_psql'")
sftp.execute("psql -h 127.0.0.1 -d {} -U {} -W -c "{}"").format(database_name, user_name, command)
sftp.close()
我认为这是个好主意,但是当我在终端中键入正确的命令时,shell 会提示输入密码(但不是必需的,当我“输入”时,一切都会执行。
有谁知道我如何“禁用”不需要的提示?