使用cURL和用户名和密码?
问题描述
我想访问一个需要用户名/密码的URL。我想尝试用 curl 来访问它。现在我正在做一些事情:
curl http://api.somesite.com/test/blah?something=123
我收到一个错误。我想我需要指定一个用户名和密码以及上述命令。
我怎样才能做到这一点?
最佳解决方案
使用-u
标志来包含用户名,并且curl将提示输入密码:
curl -u username http://example.com
您也可以在命令中包含密码,但您的密码将在bash历史记录中显示:
curl -u username:password http://example.com
次佳解决方案
做得更安全
curl --netrc-file my-password-file http://example.com
…作为传递普通用户/密码字符串在命令行是一个坏主意。
密码文件的格式是(根据man curl
):
machine host.domain.com login myself password secret
(“machine
”,“login
”和“password
”都是关键字;实际信息是这些关键字之后的内容)。
第三种解决方案
您也可以通过写入发送用户名:
curl -u USERNAME http://server.example
然后,Curl会询问您的密码,密码将不会显示在屏幕上(或者您需要复制/粘贴该命令)。
第四种方案
或同样的事情,但语法不同
curl http://username:password@api.somesite.com/test/blah?something=123
第五种方案
简单而言,最安全的方式是使用环境变量来存储/检索您的凭据。因此一个 curl 命令如:
curl -Lk -XGET -u "${API_USER}:${API_HASH}" -b cookies.txt -c cookies.txt -- "http://api.somesite.com/test/blah?something=123"
然后调用您的休息api并通过API_USER
和API_HASH
的Base64编码值的http WWW_Authentication
标头。 -Lk
只是告诉curl遵循http 30x重定向并使用不安全的tls处理(即忽略ssl错误)。而双--
只是bash语法糖停止处理命令行标志。此外,-b cookies.txt
和-c cookies.txt
标志处理Cookie与-b
发送cookie和-c
存储cookie本地。
本手册有更多的examples of authentication方法。
第六种方案
让密码最小不要弹出你的.bash_history
:
curl -u user:$(cat .password-file) http://example-domain.tld
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?