回答:
取得する:
JSONを使用:
curl -i -H "Accept: application/json" -H "Content-Type: application/json" http://hostname/resource
XMLで:
curl -H "Accept: application/xml" -H "Content-Type: application/xml" -X GET http://hostname/resource
役職:
投稿データ:
curl --data "param1=value1¶m2=value2" http://hostname/resource
ファイルをアップロードする場合:
curl --form "fileupload=@filename.txt" http://hostname/resource
RESTful HTTPポスト:
curl -X POST -d @filename http://hostname/resource
サイトにログインする場合(auth):
curl -d "username=admin&password=admin&submit=Login" --dump-header headers http://localhost/Login
curl -L -b headers http://localhost/
-H/--header <header>
(HTTP) Extra header to use when getting a web page. You may specify
any number of extra headers. Note that if you should add a custom
header that has the same name as one of the internal ones curl would
use, your externally set header will be used instead of the internal
one. This allows you to make even trickier stuff than curl would
normally do. You should not replace internally set headers without
knowing perfectly well what you're doing. Remove an internal header
by giving a replacement without content on the right side of the
colon, as in: -H "Host:".
curl will make sure that each header you add/replace get sent with
the proper end of line marker, you should thus not add that as a
part of the header content: do not add newlines or carriage returns
they will only mess things up for you.
See also the -A/--user-agent and -e/--referer options.
This option can be used multiple times to add/replace/remove multi-
ple headers.
curl --header "X-MyHeader: 123" www.google.com
-v
オプションを追加すると、curlが送信したリクエストを確認できます。
ではPHP:
curl_setopt($ch, CURLOPT_HTTPHEADER, array('HeaderName:HeaderValue'));
または、複数を設定できます。
curl_setopt($ch, CURLOPT_HTTPHEADER, array('HeaderName:HeaderValue', 'HeaderName2:HeaderValue2'));
を使用し-H or --header
ます。
GET(複数のパラメーター):
curl -X GET "http://localhost:3000/action?result1=gh&result2=ghk"
または
curl --request GET "http://localhost:3000/action?result1=gh&result2=ghk"
または
curl "http://localhost:3000/action?result1=gh&result2=ghk"
または
curl -i -H "Application/json" -H "Content-type: application/json" "http://localhost:3000/action?result1=gh&result2=ghk"
次のように、複数のヘッダー、データ(JSONなど)を送信し、Callメソッド(POST、GET)を単一のCUrl呼び出しに指定することもできます。
curl -X POST(Get or whatever) \
http://your_url.com/api/endpoint \
-H 'Content-Type: application/json' \
-H 'header-element1: header-data1' \
-H 'header-element2: header-data2' \
......その他のヘッダー................
-d '{
"JsonExArray": [
{
"json_prop": "1",
},
{
"json_prop": "2",
}
]
}'
でアナコンダてenvirement 窓のコマンドは次のようになります。GET、EXのために:
curl.exe http://127.0.0.1:5000/books
exのデータを投稿またはパッチします。
curl.exe http://127.0.0.1:5000/books/8 -X PATCH -H "Content-Type: application/json" -d '{\"rating\":\"2\"}'
PS:このタイプのエラーを回避するには、jsonデータにバックスラッシュを追加してください=> Failed to decode JSON object: Expecting value: line 1 column 1 (char 0)
この問題を回避するためだけに使用curl.exe
するのではcurl
なく:
Invoke-WebRequest : Cannot bind parameter 'Headers'. Cannot convert the "Content-Type: application/json" value of type
"System.String" to type "System.Collections.IDictionary".
At line:1 char:48
+ ... 0.1:5000/books/8 -X PATCH -H "Content-Type: application/json" -d '{\" ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidArgument: (:) [Invoke-WebRequest], ParameterBindingException
+ FullyQualifiedErrorId : CannotConvertArgumentNoMessage,Microsoft.PowerShell.Commands.InvokeWebRequestCommand