我正在尝试编写一个脚本,它将凭据保存到 .netrc 文件中,然后从文件中读取,以便将它们传递给 curl 命令并保存返回的 cookie 文件以供将来使用。我很感兴趣,如果这是传递用户名和密码的安全方式,如果中间有人攻击,如果我试图访问的服务器是通过 HTTP 访问的,他们是否能够嗅探凭据。
#!/bin/bash
IP="192.168.0.1"
user="Administrator"
pass="Password1234"
function credentials {
mkdir "${HOME}"/.netrc
rm "${HOME}"/.netrc/credentials.txt
touch "${HOME}"/.netrc/credentials.txt
{ echo "machine ${IP}"; echo "login ${user}"; echo "password ${pass}"; } >> "${HOME}"/.netrc/credentials.txt
chmod 600 "${HOME}"/.netrc/credentials.txt
}
function cookie {
curl -v -c cookie.txt -n "${HOME}"/.netrc/credentials.txt http://"${IP}"/setup.php
}
credentials
cookie
我检查了credentials.txt文件正确保存在相应的目录中,并且凭据具有正确的权限,但是当我尝试运行cookie函数时,出现以下错误:Couldn't find host 192.168.0.1 in the .netrc file; using defaults
. 为什么 curl 无法从 credentials.txt 文件中获取配置的用户名和密码?
据我了解(curl的)手册页,该选项
-n
仅允许查找.netrc
文件,但它并不期望该文件的文件路径。这是选项--netrc-file
。从手册页: