HTTPie:替代 Curl 和 Wget 的現代 HTTP 命令列用戶端

2019-04-22 12:30:00

大多數時間我們會使用 curl 命令或是 wget 命令下載檔案或者做其他事。

我們以前曾寫過 最佳命令列下載管理器 的文章。你可以點選相應的 URL 連線來瀏覽這些文章。

今天我們將討論同樣的話題。這個實用程式名為 HTTPie。

它是現代命令列 http 用戶端,也是 curlwget 命令的最佳替代品。

什麼是 HTTPie?

HTTPie (發音是 aitch-tee-tee-pie) 是一個 HTTP 命令列用戶端。

HTTPie 工具是現代的 HTTP 命令列用戶端,它能通過命令列介面與 Web 服務進行互動。

它提供一個簡單的 http 命令,允許使用簡單而自然的語法傳送任意的 HTTP 請求,並會顯示彩色的輸出。

HTTPie 能用於測試、偵錯及與 HTTP 伺服器互動。

主要特點

  • 具表達力的和直觀語法
  • 格式化的及彩色化的終端輸出
  • 內建 JSON 支援
  • 表單和檔案上傳
  • HTTPS、代理和認證
  • 任意請求資料
  • 自定義頭部
  • 持久化對談
  • 類似 wget 的下載
  • 支援 Python 2.7 和 3.x

在 Linux 下如何安裝 HTTPie

大部分 Linux 發行版都提供了系統包管理器,可以用它來安裝。

Fedora 系統,使用 DNF 命令 來安裝 httpie:

$ sudo dnf install httpie

Debian/Ubuntu 系統,使用 APT-GET 命令APT 命令 來安裝 HTTPie。

$ sudo apt install httpie

基於 Arch Linux 的系統,使用 Pacman 命令 來安裝 HTTPie。

$ sudo pacman -S httpie

RHEL/CentOS 的系統,使用 YUM 命令 來安裝 HTTPie。

$ sudo yum install httpie

openSUSE Leap 系統,使用 Zypper 命令 來安裝 HTTPie。

$ sudo zypper install httpie

用法

如何使用 HTTPie 請求 URL?

HTTPie 的基本用法是將網站的 URL 作為引數。

# http 2daygeek.comHTTP/1.1 301 Moved PermanentlyCF-RAY: 4c4a618d0c02ce6d-LHRCache-Control: max-age=3600Connection: keep-aliveDate: Tue, 09 Apr 2019 06:21:28 GMTExpires: Tue, 09 Apr 2019 07:21:28 GMTLocation: https://2daygeek.com/Server: cloudflareTransfer-Encoding: chunkedVary: Accept-Encoding

如何使用 HTTPie 下載檔案

你可以使用帶 --download 引數的 HTTPie 命令下載檔案。類似於 wget 命令。

# http --download /a/img/202006/Anbox-Easy-Way-To-Run-Android-Apps-On-Linuxglc1w4crck5.pngHTTP/1.1 200 OKAccept-Ranges: bytesCF-Cache-Status: HITCF-RAY: 4c4a65d5ca360a66-LHRCache-Control: public, max-age=7200Connection: keep-aliveContent-Length: 32066Content-Type: image/pngDate: Tue, 09 Apr 2019 06:24:23 GMTExpect-CT: max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct"Expires: Tue, 09 Apr 2019 08:24:23 GMTLast-Modified: Mon, 08 Apr 2019 04:54:25 GMTServer: cloudflareSet-Cookie: __cfduid=dd2034b2f95ae42047e082f59f2b964f71554791063; expires=Wed, 08-Apr-20 06:24:23 GMT; path=/; domain=.2daygeek.com; HttpOnly; SecureVary: Accept-EncodingDownloading 31.31 kB to "Anbox-Easy-Way-To-Run-Android-Apps-On-Linux.png"Done. 31.31 kB in 0.01187s (2.58 MB/s)

你還可以使用 -o 引數用不同的名稱儲存輸出檔案。

# http --download /a/img/202006/Anbox-Easy-Way-To-Run-Android-Apps-On-Linuxglc1w4crck5.png -o Anbox-1.pngHTTP/1.1 200 OKAccept-Ranges: bytesCF-Cache-Status: HITCF-RAY: 4c4a68194daa0a66-LHRCache-Control: public, max-age=7200Connection: keep-aliveContent-Length: 32066Content-Type: image/pngDate: Tue, 09 Apr 2019 06:25:56 GMTExpect-CT: max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct"Expires: Tue, 09 Apr 2019 08:25:56 GMTLast-Modified: Mon, 08 Apr 2019 04:54:25 GMTServer: cloudflareSet-Cookie: __cfduid=d3eea753081690f9a2d36495a74407dd71554791156; expires=Wed, 08-Apr-20 06:25:56 GMT; path=/; domain=.2daygeek.com; HttpOnly; SecureVary: Accept-EncodingDownloading 31.31 kB to "Anbox-1.png"Done. 31.31 kB in 0.01551s (1.97 MB/s)

如何使用 HTTPie 恢復部分下載?

你可以使用帶 -c 引數的 HTTPie 繼續下載。

# http --download --continue https://speed.hetzner.de/100MB.bin -o 100MB.binHTTP/1.1 206 Partial ContentConnection: keep-aliveContent-Length: 100442112Content-Range: bytes 4415488-104857599/104857600Content-Type: application/octet-streamDate: Tue, 09 Apr 2019 06:32:52 GMTETag: "5253f0fd-6400000"Last-Modified: Tue, 08 Oct 2013 11:48:13 GMTServer: nginxStrict-Transport-Security: max-age=15768000; includeSubDomainsDownloading 100.00 MB to "100MB.bin" |  24.14 %   24.14 MB    1.12 MB/s  0:01:07 ETA^C

你根據下面的輸出驗證是否同一個檔案:

[email protected]:/var/log# ls -lhtr 100MB.bin-rw-r--r-- 1 root root 25M Apr  9 01:33 100MB.bin

如何使用 HTTPie 上傳檔案?

你可以通過使用帶有小於號 < 的 HTTPie 命令上傳檔案

$ http https://transfer.sh < Anbox-1.png

如何使用帶有重定向符號 > 下載檔案?

你可以使用帶有重定向 > 符號的 HTTPie 命令下載檔案。

# http /a/img/202006/How-To-Install-And-Enable-Flatpak-Support-On-Linux-1mkxyxpvpmyi.png > Flatpak.png# ls -ltrh Flatpak.png-rw-r--r-- 1 root root 47K Apr  9 01:44 Flatpak.png

傳送一個 HTTP GET 請求?

您可以在請求中傳送 HTTP GET 方法。GET 方法會使用給定的 URI,從給定伺服器檢索資訊。

# http GET httpie.orgHTTP/1.1 301 Moved PermanentlyCF-RAY: 4c4a83a3f90dcbe6-SINCache-Control: max-age=3600Connection: keep-aliveDate: Tue, 09 Apr 2019 06:44:44 GMTExpires: Tue, 09 Apr 2019 07:44:44 GMTLocation: https://httpie.org/Server: cloudflareTransfer-Encoding: chunkedVary: Accept-Encoding

提交表單?

使用以下格式提交表單。POST 請求用於向伺服器傳送資料,例如客戶資訊、檔案上傳等。要使用 HTML 表單。

# http -f POST Ubuntu18.2daygeek.com hello='World'HTTP/1.1 200 OKAccept-Ranges: bytesConnection: Keep-AliveContent-Encoding: gzipContent-Length: 3138Content-Type: text/htmlDate: Tue, 09 Apr 2019 06:48:12 GMTETag: "2aa6-5844bf1b047fc-gzip"Keep-Alive: timeout=5, max=100Last-Modified: Sun, 17 Mar 2019 15:29:55 GMTServer: Apache/2.4.29 (Ubuntu)Vary: Accept-Encoding

執行下面的指令以檢視正在傳送的請求。

# http -v Ubuntu18.2daygeek.comGET / HTTP/1.1Accept: */*Accept-Encoding: gzip, deflateConnection: keep-aliveHost: ubuntu18.2daygeek.comUser-Agent: HTTPie/0.9.8hello=WorldHTTP/1.1 200 OKAccept-Ranges: bytesConnection: Keep-AliveContent-Encoding: gzipContent-Length: 3138Content-Type: text/htmlDate: Tue, 09 Apr 2019 06:48:30 GMTETag: "2aa6-5844bf1b047fc-gzip"Keep-Alive: timeout=5, max=100Last-Modified: Sun, 17 Mar 2019 15:29:55 GMTServer: Apache/2.4.29 (Ubuntu)Vary: Accept-Encoding

HTTP 認證?

當前支援的身份驗證認證方案是基本認證(Basic)和摘要驗證(Digest)。

基本認證:

$ http -a username:password example.org

摘要驗證:

$ http -A digest -a username:password example.org

提示輸入密碼:

$ http -a username example.org