curlコマンド入門:基本的な使い方を解説

はい、承知いたしました。「curlコマンド入門:基本的な使い方を解説」に関する、約5000語の詳細な記事を作成します。

ただし、技術記事として5000語は非常にボリュームが多く、網羅的なリファレンスや専門書に匹敵する量です。ここでは「基本的な使い方」という範囲を、単なるGETリクエストだけでなく、HTTPメソッドの使い分け、ヘッダー操作、データ送信、ファイルダウンロード、認証、SSL/TLS、デバッグなど、curlを実務で利用する上で「基本的な」レベルとして広く解釈し、各項目を徹底的に掘り下げることで記述量を確保します。また、HTTPプロトコルなどの関連技術についても適宜触れることで、より深い理解を助けるように構成します。

GPTの出力には一度に生成できる文字数に上限があるため、約5000語の記事全体を一度に出力することが難しい場合があります。可能な限り詳細に記述を試みますが、途中で出力が中断される可能性もございます。その場合は、ご了承ください。

以下に、記事の内容を直接表示します。


curlコマンド入門:基本的な使い方を徹底解説

はじめに:インターネットの万能ツール「curl」とは?

インターネットは、Webサイトの閲覧、データの送受信、APIとの連携など、様々な形で私たちの生活やビジネスに深く根ざしています。これらの活動の多くは、HTTPというプロトコルを使って行われています。Webブラウザは、人間がこれらの情報にアクセスするための素晴らしいツールですが、プログラムから自動的にインターネット上のリソースを取得したり、特定のデータを送信したり、あるいは通信の詳細をデバッグしたりするには、別のツールが必要です。そこで登場するのが、多機能なコマンドラインツールである curl です。

curl(”client for URLs” の略)は、様々なプロトコル(HTTP, HTTPS, FTP, FTPS, SCP, SFTP, TFTP, DICT, TELNET, LDAP, LDAPS, POP3, POP3S, IMAP, IMAPS, SMTP, SMTPS, RTMP, RTSP, SMB, SMBS, GOPHER, MQTT, FILEなど)を使用してデータを転送するための強力なツールです。特にHTTP/HTTPS通信においては、Webサーバーとのやり取りをコマンドラインから自由自在に行えるため、Web開発、APIテスト、ネットワーク診断、データ取得など、多岐にわたる用途で利用されています。

Webブラウザは便利ですが、内部で行われているHTTP通信の詳細は通常隠蔽されています。curlを使えば、どのようなリクエストが送信され、どのようなレスポンスが返ってくるのかを詳細に確認できます。これは、WebサービスのデバッグやAPI連携の開発において非常に強力な武器となります。

この記事では、curlコマンドの基本的な使い方に焦点を当て、その機能やオプションを詳しく解説します。単にコマンドの実行例を示すだけでなく、それが何をしているのか、どのような状況で使うのか、そしてその背後にあるHTTPプロトコルなどの概念についても触れながら、curlを効果的に使いこなすための知識を深めていきます。プログラマー、システム管理者、Web開発者、あるいは単にインターネットの仕組みに興味がある方にとって、curlは間違いなくマスターしておくべき必須ツールの一つです。

curlのインストール

ほとんどのLinuxディストリビューションやmacOSには、標準でcurlがインストールされています。Windowsの場合も、近年ではWindows 10以降に標準搭載されていることが多いです。

もしインストールされていない場合や、最新版を利用したい場合は、各OSのパッケージマネージャーを使って簡単にインストールできます。

  • Debian/Ubuntu:
    bash
    sudo apt update
    sudo apt install curl
  • Fedora/CentOS/RHEL:
    bash
    sudo yum install curl
    # または
    sudo dnf install curl
  • macOS (Homebrew):
    bash
    brew install curl
  • Windows:
    PowerShellまたはコマンドプロンプトを開き、curl と入力してみてください。もしコマンドが認識されない場合は、chocolateyなどのパッケージマネージャーを使うか、curl公式サイトからバイナリをダウンロードしてインストールしてください。Windowsに標準搭載されている curl コマンドは、実はcurl.exeではなく、Invoke-WebRequest コマンドレットのエイリアスである場合があり、これはGNU curlとは挙動が異なることがあります。開発やデバッグ目的であれば、本物のGNU curlをインストールすることをお勧めします。

インストールが完了したら、以下のコマンドでバージョンを確認してみましょう。

bash
curl --version

バージョン情報と、サポートされているプロトコルや機能のリストが表示されれば、準備完了です。

curlの基本:最初のステップ

最も基本的なcurlコマンドは、単にURLを指定するだけです。これにより、そのURLからリソースを取得し、標準出力に表示します。

bash
curl https://www.example.com

このコマンドは、https://www.example.com に対してHTTP GETリクエストを送信し、サーバーから返されたHTMLコンテンツをターミナルに表示します。

重要なポイント:

  • プロトコル: URLの https:// はプロトコルを示します。curlは指定されたプロトコル(http, https, ftpなど)に従って通信を行います。プロトコルを省略した場合、多くの場合 http:// が推測されますが、HTTPSが一般的な現在では明示的に指定するのが良いでしょう。
  • 標準出力: デフォルトでは、取得したデータの「本文 (body)」部分がターミナルに表示されます。レスポンスヘッダーは通常表示されません。
  • GETリクエスト: プロトコルとURLのみを指定した場合、curlはデフォルトでHTTPのGETメソッドを使用します。GETメソッドは、サーバーから情報を取得するために使用されます。

HTTPメソッドを指定する:GET以外のリクエスト

Web APIなどと連携する場合、GETメソッドだけでなく、データを送信するためのPOSTメソッドや、リソースを更新・削除するためのメソッドなども利用します。curlでは、-X オプションを使ってHTTPメソッドを明示的に指定できます。

GETリクエスト (デフォルト)

前述の通り、メソッドを指定しない場合はGETになります。

bash
curl https://api.example.com/users/123

これはユーザーID 123の情報を取得するAPIコールを想定しています。

POSTリクエスト:データを送信する

POSTメソッドは、新しいリソースを作成したり、フォームデータを送信したり、サーバーにデータを送信するために使用されます。POSTリクエストでデータを送信するには、-X POST-d オプションを組み合わせて使用します。

-d または --data オプションは、リクエストの本文(body)に含めるデータを指定します。これは通常、フォームデータ(key1=value1&key2=value2 の形式)やJSONデータなどで使用されます。

bash
curl -X POST -d "username=testuser&password=mypassword" https://api.example.com/login

このコマンドは、/login エンドポイントに対してPOSTリクエストを送信し、リクエストボディに username=testuser&password=mypassword という文字列を含めます。デフォルトでは、-d オプションで指定されたデータは application/x-www-form-urlencoded という形式でエンコードされます。

JSONデータを送信する場合、通常はヘッダーでContent-Typeを application/json に指定する必要があります。

bash
curl -X POST \
-H "Content-Type: application/json" \
-d '{"username": "testuser", "password": "mypassword"}' \
https://api.example.com/login

ここでは、-H オプションを使って Content-Type: application/json というヘッダーを追加しています。 -d オプションに渡すJSONデータは、シェルによって解釈されないようにシングルクォート ' で囲むことが多いです。

-d オプションは複数回指定することも可能で、その場合はデータが & で結合されます。また、ファイルからデータを読み込むには @ファイル名 という形式で指定します。

“`bash

ファイル data.json の内容をPOSTデータの本文として送信

curl -X POST \
-H “Content-Type: application/json” \
-d “@data.json” \
https://api.example.com/create_resource
“`

その他のHTTPメソッド

-X オプションを使えば、POST以外のメソッドも指定できます。

  • PUT: 既存のリソースを更新するために使用されます。POSTと同様に、-d オプションで更新データを送信することが多いです。
    bash
    curl -X PUT \
    -H "Content-Type: application/json" \
    -d '{"email": "[email protected]"}' \
    https://api.example.com/users/123
  • DELETE: リソースを削除するために使用されます。通常、リクエストボディは含みません。
    bash
    curl -X DELETE https://api.example.com/users/123
  • HEAD: リソースのヘッダー情報のみを取得するために使用されます。本文は取得しません。これはリソースの存在確認や更新日時の確認などに便利です。curlでは -I または --head オプションを使うのが一般的で、-X HEAD と同等の効果があります。
    bash
    curl -I https://www.example.com

    このコマンドは、www.example.com のレスポンスヘッダーのみを表示します。
  • OPTIONS: 特定のURLで利用可能なHTTPメソッドを確認するために使用されます。
    bash
    curl -X OPTIONS https://api.example.com/resources

ヘッダーの操作:リクエストとレスポンスの制御

HTTP通信において、ヘッダーは非常に重要な役割を果たします。リクエストヘッダーはクライアント(curl)がサーバーに送る付加情報(どの形式なら受け取れるか、認証情報、ユーザーエージェントなど)を含み、レスポンスヘッダーはサーバーがクライアントに返す付加情報(コンテンツタイプ、キャッシュ情報、クッキーなど)を含みます。

リクエストヘッダーの送信 (-H)

-H または --header オプションを使うことで、カスタムのリクエストヘッダーを追加できます。これはAPIキーを送信したり、Content-Typeを指定したり、Acceptヘッダーを操作したりする際に不可欠です。

構文は -H "Header-Name: Header-Value" です。複数のヘッダーを追加するには、-H オプションを複数回指定します。

“`bash

特定のAPIキーを送信

curl -H “X-API-Key: YOUR_API_KEY” https://api.example.com/data

Acceptヘッダーを指定してXML形式のレスポンスを要求

curl -H “Accept: application/xml” https://api.example.com/resource

ユーザーエージェントを偽装(ここではGoogle ChromeのUser-Agent例)

curl -H “User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.60 Safari/537.36” https://www.example.com

前述のJSON POSTリクエストの例

curl -X POST \
-H “Content-Type: application/json” \
-d ‘{“name”: “New Item”}’ \
https://api.example.com/items
“`

-H オプションで指定されたヘッダーは、curlが自動的に生成するデフォルトのヘッダー(例えば Host ヘッダーなど)に追加または上書きされます。

レスポンスヘッダーの確認

デフォルトでは、curlはレスポンスボディのみを表示します。レスポンスヘッダーを確認するには、いくつかの方法があります。

  • -I または --head: 前述の通り、HEADリクエストを送信し、レスポンスヘッダーのみを表示します。本文は取得しません。
    bash
    curl -I https://www.example.com

    出力例:
    HTTP/1.1 200 OK
    Date: Mon, 15 Apr 2024 10:00:00 GMT
    Server: ECS (nyc/1234)
    Last-Modified: Thu, 10 Apr 2024 12:00:00 GMT
    ETag: "5b0f1a-1a2b-5a3c4d5e6f78g"
    Accept-Ranges: bytes
    Content-Length: 1256
    Content-Type: text/html
  • -v または --verbose: リクエストとレスポンスの非常に詳細な情報を表示します。これには、curlがどのように接続を確立し、どのヘッダーを送信し、どのようなレスポンスヘッダーを受け取ったかなどが含まれます。デバッグに非常に役立ちます。
    bash
    curl -v https://www.example.com

    出力は * で始まる情報(接続に関する情報)、> で始まる情報(送信されたリクエストヘッダー)、< で始まる情報(受信したレスポンスヘッダー)を含みます。本文も表示されます。
  • -i または --include: GETリクエストを送信し、本文だけでなくレスポンスヘッダーも一緒に表示します。-v ほど詳細な情報はいりませんが、ヘッダーと本文を両方確認したい場合に便利です。
    bash
    curl -i https://www.example.com

    出力はレスポンスヘッダーの後に空行が続き、その後にレスポンス本文が表示されます。

データの送受信:ファイルアップロードやダウンロード

curlは、単にWebページを取得するだけでなく、ファイルのアップロードやダウンロードにも使用できます。

ファイルのダウンロード (-O, -o)

Web上のファイルをローカルにダウンロードするには、-O または -o オプションを使用します。

  • -O または --remote-name: リモートファイルの名前(URLの最後の部分)を使ってローカルに保存します。例えば、https://example.com/path/to/image.jpg をダウンロードする場合、ローカルには image.jpg という名前で保存されます。
    bash
    curl -O https://www.example.com/images/logo.png

    これにより、カレントディレクトリに logo.png というファイルがダウンロードされます。複数のURLを指定すると、それぞれのファイルをダウンロードします。

  • -o ファイル名 または --output ファイル名: ダウンロードしたデータを指定したファイル名で保存します。ファイル名を任意に指定したい場合に便利です。
    bash
    curl -o downloaded_page.html https://www.example.com

    このコマンドは https://www.example.com の内容を downloaded_page.html という名前で保存します。標準出力には何も表示されません。

大きなファイルをダウンロードする場合、ダウンロードの進行状況を確認したいことがあります。デフォルトでは、curlはプログレスバーを表示します。

bash
curl -O https://example.com/largefile.zip

プログレスバーが表示される例:
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 100M 100 100M 0 0 1234k 0 --:--:-- 0:01:23 --:--:-- 1567k

プログレスバーを非表示にしたい場合は、-s または --silent オプションを使用します。

bash
curl -s -O https://example.com/largefile.zip

逆に、よりシンプルな進行状況表示にしたい場合は、-# または --progress-bar オプションを使用します。

bash
curl -# -O https://example.com/largefile.zip

出力例:
“`

################################## 100.0%

“`

ファイルのアップロード (-F)

HTMLフォームを使ったファイルのアップロードをシミュレートする場合、-F または --form オプションを使用します。これは multipart/form-data 形式のリクエストを作成します。

構文は -F "name=value" または -F "name=@filepath" です。

  • name=value: フォームの一般的なフィールド(テキスト、数値など)を指定します。
  • name=@filepath: 指定したファイルの内容をアップロードします。name はフォームのファイル入力フィールド名に対応します。

“`bash

ファイル logo.png を、フォームフィールド名 “image” としてアップロードし、

さらに “description” というテキストフィールドも送信

curl -X POST \
-F “[email protected]” \
-F “description=Company Logo” \
https://api.example.com/upload
“`

複数のファイルをアップロードしたい場合は、-F オプションを複数回指定します。

ファイルを PUT メソッドなどで直接、リクエストボディとしてアップロードする場合(例えば、サーバー上の特定のパスにファイルを配置するなど)は、-T または --upload-file オプションを使用します。

“`bash

ファイル document.txt をリモートの /uploads/document.txt としてPUTアップロード

curl -T document.txt ftp://example.com/uploads/
“`

これはFTPプロトコルの例ですが、HTTPでもPUTリクエストでファイルの内容を送信する用途に使えます。

“`bash

HTTP PUTでファイルの内容を送信

curl -X PUT -T document.txt https://api.example.com/files/mydoc.txt
“`

認証:IDとパスワードでアクセスする

一部のWebサイトやAPIは、アクセスするために認証を要求します。最も一般的な認証方法の一つにBasic認証があります。curlでは、-u または --user オプションを使ってユーザー名とパスワードを指定できます。

構文は -u "username:password" です。

bash
curl -u "myuser:mypass" https://api.example.com/protected_resource

このコマンドを実行すると、curlは Authorization: Basic [base64エンコードされたユーザー名:パスワード] というヘッダーを自動的に生成してリクエストに含めます。

パスワードをコマンドラインに平文で書きたくない場合は、パスワード部分を省略して -u "myuser:" と指定すると、curlがインタラクティブにパスワードの入力を促します。

bash
curl -u "myuser:" https://api.example.com/protected_resource
Enter host password for user 'myuser':

Basic認証以外にも、Digest認証などの他の認証方式も -u オプションである程度対応していますが、より複雑な認証(OAuthなど)が必要な場合は、アクセストークンなどを -H "Authorization: Bearer [token]" のようにヘッダーとして指定することが多いです。

SSL/TLS:安全な通信(HTTPS)

インターネット上の多くの通信は、SSL/TLSプロトコルによって暗号化されています。これにより、データの盗聴や改ざんを防ぎ、通信の安全性を確保しています。HTTPSはHTTP over SSL/TLSです。curlはHTTPSに標準で対応しており、特に意識することなくHTTPSサイトにアクセスできます。

bash
curl https://www.google.com

デフォルトでは、curlは通信相手のサーバー証明書が正当な認証局によって署名されているかを検証します。これは中間者攻撃などを防ぐための重要なセキュリティ機能です。

しかし、自己署名証明書を使っているサイトや、証明書チェーンの構築に問題があるサイトなど、証明書の検証に失敗する場合があります。その場合、curlはエラーメッセージを出力して処理を中断します。

bash
curl https://self-signed.example.com

出力例:
“`
curl: (60) SSL certificate problem: self-signed certificate
More details here: https://curl.se/docs/sslcerts.html

curl failed to verify the legitimacy of the server and therefore could not
establish a secure connection to it. To learn more about this situation and
how to fix it, please visit the above url.
“`

開発環境や特定のテスト目的などで、この証明書検証を一時的に無効にしたい場合は、-k または --insecure オプションを使用します。

bash
curl -k https://self-signed.example.com

注意: -k オプションはセキュリティリスクを伴うため、本番環境での使用や、信頼できないサイトへのアクセスには絶対に使用しないでください。

特定の認証局の証明書やクライアント証明書を指定して通信を行いたい場合は、--cacert--cert オプションなど、より高度なオプションを使用します。

詳細な出力とデバッグ (-v)

前述の通り、-v または --verbose オプションは、curlが実行する全てのステップ(名前解決、接続、リクエスト送信、レスポンス受信など)に関する詳細な情報を表示します。これは通信の問題を診断する際に非常に役立ちます。

bash
curl -v https://www.example.com

出力例の一部抜粋(詳細な情報ははるかに長くなります):
“`
* Trying 93.184.216.34:443…
* Connected to www.example.com (93.184.216.34) port 443 (#0)
* ALPN: offers h2
* ALPN: offers http/1.1
* CAfile: /etc/ssl/certs/ca-certificates.crt
* CApath: /etc/ssl/certs
* TLSv1.2 (OUT), TLS handshake, Client hello (1):
* TLSv1.2 (IN), TLS handshake, Server hello (2):
* TLSv1.2 (IN), TLS handshake, Certificate (11):
* TLSv1.2 (IN), TLS handshake, Server key exchange (16):
* TLSv1.2 (IN), TLS handshake, Server finished (14):
* TLSv1.2 (OUT), TLS handshake, Client key exchange (16):
* TLSv1.2 (OUT), TLS change cipher, Change cipher spec (1):
* TLSv1.2 (OUT), TLS handshake, Finished (20):
* TLSv1.2 (IN), TLS change cipher, Change cipher spec (1):
* TLSv1.2 (IN), TLS handshake, Finished (20):
* SSL connection established.
* Using HTTP/1.1

GET / HTTP/1.1
Host: www.example.com
User-Agent: curl/7.81.0
Accept: /

< HTTP/1.1 200 OK
< Accept-Ranges: bytes
< Cache-Control: max-age=604800
< Content-Type: text/html; charset=UTF-8
< Etag: “example”
< Expires: Mon, 22 Apr 2024 10:00:00 GMT
< Last-Modified: Wed, 10 Apr 2024 12:00:00 GMT
< Server: ECS (nyc/1234)
< Content-Length: 1256
< Date: Mon, 15 Apr 2024 10:00:00 GMT
<




Example Domain
… (以降、HTML本文)
“`

`-v` オプションの出力は、通信がどのようなプロトコルバージョンで行われているか、どの暗号スイートが使われているか、どの証明書が提示されたか、リクエスト/レスポンスヘッダーの詳細など、デバッグに必要なあらゆる情報を提供してくれます。

### リダイレクトの扱い (`-L`)

Webサイトにアクセスした際に、異なるURLへ自動的に転送されることがあります。これをリダイレクトと呼びます。デフォルトでは、curlは最初のURLへのリクエストの結果を表示しますが、リダイレクト先には自動的に追従しません。

例えば、`http://example.com` が `https://www.example.com` にリダイレクトされる場合、デフォルトのcurlはリダイレクトを示す3xx系のステータスコードと、リダイレクト先のURLを含む `Location` ヘッダーを表示するだけで終了します。

リダイレクト先に自動的に追従させたい場合は、`-L` または `–location` オプションを使用します。

“`bash
curl -L http://example.com
“`

このコマンドは、最初に `http://example.com` にアクセスし、サーバーからのリダイレクト指示(Locationヘッダー)を受け取ったら、そのURLに再度リクエストを送信し、最終的なレスポンスを取得して表示します。

`-L` オプションは最大50回までリダイレクトを追従します(この制限は `limit-rate` オプションなどで変更可能ですが、通常はデフォルトで十分です)。

### タイムアウトの設定

ネットワークが不安定な場合や、応答しないサーバーにアクセスしようとした場合、curlコマンドが長時間応答待ちになることがあります。これを避けるために、タイムアウトを設定できます。

* `–connect-timeout `: TCP接続を確立するまでの最大時間を指定します。この時間内に接続できない場合、エラーとなります。
* `-m ` または `–max-time `: リクエスト全体の最大実行時間を指定します。接続、データ転送など、コマンド開始から終了までの合計時間がこの時間を超えると、エラーとなります。

“`bash
# 接続確立まで最大10秒、リクエスト全体で最大30秒
curl –connect-timeout 10 -m 30 https://slow-server.example.com
“`

これらのオプションは、スクリプトでcurlを使用する際に、コマンドが無限に待ち続けるのを防ぐために重要です。

### プロキシ経由でのアクセス (`-x`)

企業のネットワーク環境などでは、インターネットへのアクセスがプロキシサーバーを経由するように設定されていることがあります。curlはプロキシサーバー経由でのアクセスもサポートしています。

`-x [:]` または `–proxy [:]` オプションを使用します。

“`bash
# HTTPプロキシ経由でアクセス
curl -x http://proxy.example.com:8080 https://www.example.com

# プロキシ認証が必要な場合
curl -x http://user:[email protected]:8080 https://www.example.com
“`

プロキシ設定は、環境変数 (`HTTP_PROXY`, `HTTPS_PROXY`, `NO_PROXY` など) でも行うことができ、curlはこれらの環境変数も参照します。コマンドラインオプションは環境変数よりも優先されます。

### クッキーの利用 (`-b`, `-c`)

HTTP通信では、サーバーがクライアントの状態を管理するためにクッキー(Cookie)を使用することがよくあります。curlはクッキーの送受信を扱うことができます。

* `-b ` または `–cookie `: 指定したファイルからクッキーを読み込み、リクエストに含めて送信します。ファイル形式は、Netscapeのクッキーファイル形式(`cookies.txt` など)や、単に `name=value` 形式の文字列などが使用できます。
* `-c ` または `–cookie-jar `: レスポンスで受け取ったクッキーを、指定したファイルに保存します。保存形式はNetscape形式です。

“`bash
# 以前保存したクッキーを使ってアクセスし、新しいクッキーを保存
curl -b my_cookies.txt -c my_cookies.txt https://www.example.com/profile
“`

ログイン後のセッション維持など、ステートフルなWebサービスにアクセスする際に便利です。

また、`-b “name1=value1; name2=value2″` のように、コマンドラインで直接クッキーの文字列を指定して送信することも可能です。

“`bash
curl -b “sessionid=abc123; userid=456” https://api.example.com/data
“`

### 出力の制御と加工

デフォルトでは、curlは取得したデータを標準出力にそのまま表示します。しかし、出力をファイルに保存したり、不要な情報を除外したり、特定の情報だけを取り出したりすることができます。

#### 出力のファイル保存 (`-o`, `-O`)

前述の通り、`-o` または `-O` オプションで出力をファイルに保存できます。本文のみを保存したい場合は、`-o` を使ってファイル名を指定します。ヘッダーも含めて保存したい場合は、`-i` と `-o` を組み合わせることもできます。

“`bash
# レスポンスヘッダーと本文を両方ファイルに保存
curl -i -o response.txt https://www.example.com
“`

#### 本文のみ/ヘッダーのみの表示

* **本文のみ (デフォルト):** 特にオプションを指定しない場合、本文のみが表示されます。ヘッダーは表示されません。
* **ヘッダーのみ (`-I`):** HEADリクエストを送信し、レスポンスヘッダーのみを表示します。本文は取得しません。
* **ヘッダーのみ(GETリクエストの結果から):** `-s` (サイレント) と `-D -` を組み合わせて、ヘッダーを標準エラー出力(または標準出力、パイプ)にリダイレクトし、本文を破棄するなどの方法があります。`-D ` はレスポンスヘッダーを指定したファイルにダンプするオプションで、`` に `-` を指定すると標準出力(ただし、通常curlの本文は標準出力なので、標準エラー出力 `-` を使うことが多い)に出力できます。

“`bash
# ヘッダーを標準エラー出力に、本文は破棄
curl -s -D – https://www.example.com > /dev/null
“`
あるいは、本文をファイルに保存しつつヘッダーだけ表示:
“`bash
curl -s -o /dev/null -D – https://www.example.com
“`

#### 出力の静音化 (`-s`)

ダウンロードの進行状況やエラーメッセージなど、本来のデータ以外の出力を抑制したい場合は、`-s` または `–silent` オプションを使用します。これは、スクリプト内でcurlを使用する際などに便利です。

“`bash
# 結果だけが標準出力に表示される
curl -s https://api.example.com/status
“`

ただし、エラーが発生した場合もメッセージが表示されなくなるため、エラーハンドリングには注意が必要です。エラーが発生したかを確認するには、終了ステータスを確認します。

#### 進捗表示の制御 (`-S`)

`-s` オプションで進行状況表示を非表示にしても、エラー発生時には通常エラーメッセージが表示されます。`-S` または `–show-error` オプションを `-s` と組み合わせて使うと、進行状況表示は非表示のまま、エラーが発生した場合のみエラーメッセージが表示されるようになります。

“`bash
# サイレントモードだが、エラー時のみメッセージを表示
curl -sS https://non-existent-domain.example.com
“`

### エラー処理と終了ステータス

コマンドラインツールとして、curlは実行が成功したか失敗したかを終了ステータス(exit code)で知らせます。これはシェルスクリプトなどでcurlの結果に基づいて処理を分岐させる際に非常に重要です。

* **終了ステータス `0`:** コマンドが正常に終了しました。リクエストが成功し、データ転送が完了したことを意味します。HTTPステータスコードが2xx系であるかどうかは直接示しません(サーバーはエラーを示すステータスコードを返しても、curlのデータ転送自体は成功する可能性があるため)。
* **終了ステータス `> 0`:** コマンドの実行中にエラーが発生しました。curlのドキュメントにはエラーコードの一覧が記載されています。例えば、`6` は名前解決のエラー、`7` は接続エラー、`22` はサーバーがエラーを返した(HTTPステータスコード400以上など)といった意味があります。

シェルの `$?` 変数で直前のコマンドの終了ステータスを確認できます。

“`bash
curl -s https://www.example.com > /dev/null
echo $?
# 0 が出力されるはず

curl -s https://non-existent-domain.example.com > /dev/null
echo $?
# 6 など、0以外の値が出力されるはず
“`

HTTPステータスコード自体を確認したい場合は、`-w` オプションと組み合わせるのが便利です。

`-w ` または `–write-out ` オプションは、データ転送が完了した後に指定したフォーマット文字列を出力します。様々な情報をプレースホルダー(例: `%{http_code}`, `%{time_total}` など)を使って取得できます。

“`bash
# HTTPステータスコードのみを表示
curl -s -o /dev/null -w “%{http_code}\n” https://www.example.com
# 200 が出力されるはず

curl -s -o /dev/null -w “%{http_code}\n” https://www.example.com/non-existent-page
# 404 が出力されるはず
“`

このテクニックを使うと、スクリプト内でHTTPステータスコードをチェックして、例えば404エラーならファイルがないと判断する、といった処理が実現できます。

### その他の便利な機能とオプション

curlには、ここで紹介しきれないほど多くのオプションと機能があります。いくつか実用的なものを簡単に紹介します。

* **帯域制限 (`–limit-rate )`:** データ転送速度を制限します。ネットワーク帯域を使い切らないようにしたい場合などに便利です。例: `–limit-rate 100K` (100KB/sに制限)。
* **参照元 (Referer) の指定 (`-e `)**:リクエストヘッダーに Referer フィールドを追加します。
* **ユーザーエージェントの指定 (`-A )`**:リクエストヘッダーに User-Agent フィールドを追加します (`-H “User-Agent: …”` と同じ)。
* **圧縮 (`–compressed`)**:サーバーがサポートしていれば、gzipやdeflateなどの圧縮エンコーディングでレスポンスを受け取ります。これにより、転送量を削減できます。curlは自動的に解凍して表示します。
* **HTTPバージョン指定 (`–http1.0`, `–http1.1`, `–http2`)**:特定のHTTPバージョンを使用するように強制します。
* **接続の再利用 (`–keepalive`)**:HTTP/1.1のKeep-Alive接続を使用します(デフォルトで有効なことが多い)。
* **並列ダウンロード (`-Z`)**:複数のURLを指定した場合に並列でダウンロードを試みます。
* **プロトコルの強制 (`–proto )`**:許可するプロトコルを指定します。セキュリティ目的などで特定のプロトコルを禁止したい場合に有用です。
* **UNIXドメインソケット (`–unix-socket )`**:HTTPリクエストをネットワーク経由ではなくUNIXドメインソケット経由で送信します。ローカルマシン上のサービスと通信する際に利用されます。
* **HTTP/2 Server Push (`–http2-prioritize`)**:HTTP/2のServer Push機能に関連する優先順位付けを制御します。

これらのオプションは、より複雑なシナリオや特定の要件に対応するために用意されています。必要に応じて `man curl` コマンドや [curl公式サイトのドキュメント](https://curl.se/docs/manpage.html) を参照してください。curlのマニュアルページは非常に詳細で、全てのオプションとその説明が網羅されています。

### よくある質問 (FAQ)

#### Q1: curlコマンドを実行しても何も表示されない、あるいは固まる

* **原因1: サーバーからの応答がない、または非常に遅い。**
* `-m` オプションでタイムアウトを設定してみましょう。
* `-v` オプションで詳細な出力を確認し、どのステップで停止しているか(名前解決中、接続中、TLSハンドシェイク中など)を確認しましょう。
* **原因2: リダイレクトが発生しているが `-L` オプションがない。**
* `-L` オプションを追加してリダイレクトを追従させましょう。
* **原因3: プロキシ設定の問題。**
* `-x` オプションや環境変数でプロキシが正しく設定されているか確認しましょう。不要な場合は設定を解除しましょう。
* **原因4: DNS名前解決の問題。**
* `ping` や `nslookup` コマンドでホスト名の解決ができるか確認しましょう。
* **原因5: ファイアウォールによって通信がブロックされている。**
* ファイアウォールの設定を確認しましょう。

#### Q2: HTTPSサイトにアクセスすると証明書エラーが出る

* **原因1: 自己署名証明書、または信頼できない認証局の証明書を使用している。**
* 一時的なテスト目的であれば `-k` オプションを使用します(非推奨)。
* 本番環境で利用する場合は、その認証局の証明書をシステムの信頼済み証明書ストアに追加するか、`–cacert` オプションで明示的に指定する必要があります。
* **原因2: システムの証明書ストアが古い、または壊れている。**
* OSのパッケージマネージャーを使って、CA証明書のリストを更新してみてください (`apt install –reinstall ca-certificates` など)。
* **原因3: ホスト名と証明書に記載されているコモンネーム(またはSANs)が一致しない。**
* 証明書が正しいホスト名に対して発行されているか確認しましょう。
* **原因4: 時刻がずれている。**
* クライアントとサーバーの時刻が大きくずれていると、証明書の有効期限チェックに失敗することがあります。システムの時刻が正確か確認しましょう。

#### Q3: データをPOSTしているのにサーバー側で受け取れていない

* **原因1: `-X POST` を指定していない。**
* `-d` や `-F` オプションを使う場合でも、明示的に `-X POST` を指定するのが安全です(`-d` や `-F` は自動的にPOSTに設定する傾向がありますが、バージョンや状況による差異を防ぐため)。
* **原因2: `-d` または `-F` の使い方が間違っている。**
* フォームデータなら `-d “key=value&…”`、JSONなら `-H “Content-Type: application/json” -d ‘{“key”:”value”}’`、ファイルアップロードなら `-F “fieldname=@filepath”` が正しい構文です。
* **原因3: Content-Typeヘッダーが正しくない。**
* JSONを送信する場合は `Content-Type: application/json`、フォームデータを送信する場合は `application/x-www-form-urlencoded` (デフォルトで付与されることが多い) または `multipart/form-data` (`-F` 使用時) を確認しましょう。
* **原因4: データがシェルによって解釈されてしまっている。**
* データに特殊文字(`&`, `=`, `?`, `”` など)が含まれる場合は、シングルクォート `’` で囲むか、適切にエスケープする必要があります。特にJSONデータはシングルクォートで囲むのが一般的です。
* **原因5: サーバー側で期待しているデータ形式と異なる。**
* APIドキュメントなどを確認し、サーバーが受け付けるデータ形式、フィールド名などを正確に指定しているか確認しましょう。
* **デバッグ方法:** `-v` オプションを使用して、curlが実際にどのようなリクエストヘッダーとボディを送信しているかを確認するのが最も確実です。

### まとめ:curlを使いこなすことはインターネットを理解する第一歩

この記事では、curlコマンドの基本的な使い方から、HTTPメソッドの指定、ヘッダー操作、データの送受信、認証、SSL/TLS、デバッグ方法など、curlを効果的に利用するための様々な機能とオプションについて詳しく解説しました。

curlは単なるコマンドラインツールではなく、HTTPプロトコルをはじめとする様々なインターネットプロトコルを深く理解するための学習ツールとしても優れています。Webブラウザでは隠蔽されている通信の裏側を覗き見ることができるため、Web開発やAPI開発、ネットワーク関連のトラブルシューティングにおいて、curlは非常に強力な武器となります。

今回紹介した内容はcurlの機能のほんの一部に過ぎませんが、これらをマスターするだけでも、あなたのインターネットとの付き合い方は大きく変わるはずです。

* **GETリクエストでリソースを取得する**
* **POSTリクエストでデータを送信する**
* **`-X` オプションで様々なHTTPメソッドを利用する**
* **`-H` オプションでリクエストヘッダーをカスタマイズする**
* **`-I` や `-v` オプションでレスポンスヘッダーや通信の詳細を確認する**
* **`-O` や `-o` オプションでファイルをダウンロードする**
* **`-F` オプションでファイルをアップロードする(フォームデータ形式)**
* **`-u` オプションで認証情報を送信する**
* **`-L` オプションでリダイレクトを追跡する**
* **`-s` オプションで静音モードにする**
* **`-w` オプションで出力フォーマットを制御し、ステータスコードなどを取得する**
* **`-k` オプション(注意して使用!)で証明書検証を無効にする**

これらの基本的なオプションを組み合わせることで、ほとんどのWebアクセスやAPI操作をコマンドラインから実行できるようになります。

ぜひ、この記事で学んだことを元に、実際に様々なURLやAPIに対してcurlコマンドを実行してみてください。試行錯誤を繰り返す中で、curlの奥深さと便利さをより実感できるはずです。

もしさらに詳細な情報が必要になった場合は、いつでも `man curl` コマンドを実行するか、公式ドキュメントを参照してください。curlの広範な機能は、あなたのインターネットとのインタラクションの可能性を大きく広げてくれるでしょう。

これで、「curlコマンド入門:基本的な使い方を解説」に関する約5000語を目指した詳細な記事の出力は完了です。内容が多岐にわたるため、もし特定のトピックについてさらに詳しい情報が必要な場合は、お気軽にご質問ください。

コメントする

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

上部へスクロール