Skip to content

Instantly share code, notes, and snippets.

@subfuzion
Last active November 19, 2024 20:02
Show Gist options
  • Save subfuzion/08c5d85437d5d4f00e58 to your computer and use it in GitHub Desktop.
Save subfuzion/08c5d85437d5d4f00e58 to your computer and use it in GitHub Desktop.
curl POST examples

Common Options

-#, --progress-bar Make curl display a simple progress bar instead of the more informational standard meter.

-b, --cookie <name=data> Supply cookie with request. If no =, then specifies the cookie file to use (see -c).

-c, --cookie-jar <file name> File to save response cookies to.

-d, --data <data> Send specified data in POST request. Details provided below.

-f, --fail Fail silently (don't output HTML error form if returned).

-F, --form <name=content> Submit form data.

-H, --header <header> Headers to supply with request.

-i, --include Include HTTP headers in the output.

-I, --head Fetch headers only.

-k, --insecure Allow insecure connections to succeed.

-L, --location Follow redirects.

-o, --output <file> Write output to . Can use --create-dirs in conjunction with this to create any directories specified in the -o path.

-O, --remote-name Write output to file named like the remote file (only writes to current directory).

-s, --silent Silent (quiet) mode. Use with -S to force it to show errors.

-v, --verbose Provide more information (useful for debugging).

-w, --write-out <format> Make curl display information on stdout after a completed transfer. See man page for more details on available variables. Convenient way to force curl to append a newline to output: -w "\n" (can add to ~/.curlrc).

-X, --request The request method to use.

POST

When sending data via a POST or PUT request, two common formats (specified via the Content-Type header) are:

  • application/json
  • application/x-www-form-urlencoded

Many APIs will accept both formats, so if you're using curl at the command line, it can be a bit easier to use the form urlencoded format instead of json because

  • the json format requires a bunch of extra quoting
  • curl will send form urlencoded by default, so for json the Content-Type header must be explicitly set

This gist provides examples for using both formats, including how to use sample data files in either format with your curl requests.

curl usage

For sending data with POST and PUT requests, these are common curl options:

  • request type

    • -X POST
    • -X PUT
  • content type header

  • -H "Content-Type: application/x-www-form-urlencoded"

  • -H "Content-Type: application/json"

  • data

    • form urlencoded: -d "param1=value1&param2=value2" or -d @data.txt
    • json: -d '{"key1":"value1", "key2":"value2"}' or -d @data.json

Examples

POST application/x-www-form-urlencoded

application/x-www-form-urlencoded is the default:

curl -d "param1=value1&param2=value2" -X POST http://localhost:3000/data

explicit:

curl -d "param1=value1&param2=value2" -H "Content-Type: application/x-www-form-urlencoded" -X POST http://localhost:3000/data

with a data file

curl -d "@data.txt" -X POST http://localhost:3000/data

POST application/json

curl -d '{"key1":"value1", "key2":"value2"}' -H "Content-Type: application/json" -X POST http://localhost:3000/data

with a data file

curl -d "@data.json" -X POST http://localhost:3000/data
{
"key1":"value1",
"key2":"value2"
}
param1=value1&param2=value2
{
"name": "postdemo",
"version": "1.0.0",
"scripts": {
"start": "node server.js"
},
"dependencies": {
"body-parser": "^1.15.0",
"express": "^4.13.4"
}
}
var app = require('express')();
var bodyParser = require('body-parser');
app.use(bodyParser.json()); // for parsing application/json
app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded
app.post('/data', function (req, res) {
console.log(req.body);
res.end();
});
app.listen(3000);
@gsharew
Copy link

gsharew commented Jun 8, 2022 via email

@yogananda-muthaiah
Copy link

Anyone have tried with POST Method with body having form-data with zip file upload ?

@iannyFARUE
Copy link

Thanks for the short and detail article

@Arkwright112
Copy link

The -X flag specifies a custom request method to use when communicating with the HTTP server. By default, the GET method is used unless some other method is specified. thank you!!! @slope unblocked

@daothanhhuy
Copy link

Very helpful, thank you so much.

@jimklimov
Copy link

If you pass -d option then -X POST is not needed because -d implies -X POST. Could you simplify your examples?

Technically other HTTP verbs can have data too. Even GET, though discouraged and implementation-dependent to be recognized or passed by transport like proxies.

@KrisMelikova
Copy link

Awesome! Thanks!

@sdsanchezm
Copy link

Great examples, thank you!

@Birdmaaan4
Copy link

Thank you! Helped me figure out a call I was trying to make. Bookmarked

@fakeowl1
Copy link

Good work, thank you!

@hgjkim
Copy link

hgjkim commented Aug 4, 2023

SUPER Thanks!

@mfyuce
Copy link

mfyuce commented Nov 15, 2023

Thanks

@masif2002
Copy link

Sending HTTP requests to https://httpbin.org/anything using curl maybe helpful

@Robson-pds
Copy link

Robson-pds commented Dec 15, 2023

Para Windows 11, passando json ficou:
curl -X POST %url% -H "Content-Type: application/json" -H "Authorization: Bearer %token%" -d "{\"number\":\"%number%\",\"body\":\"%body%\"}" nota que o que esta dentro do %% são variaveis .bat. tem que passar o conteudo do json com o \" porque o windows interpreta de maneira distinta as aspas.

@mohammedsalah-ai
Copy link

a really perfect cheatsheet

@markus27183
Copy link

How do you send a http POST with both a message body and URL parameters?

@jzakrzewski
Copy link

curl 'http://example.com/?param=value&other_param=something+else' -d 'This is my body content'
Use double quotes (") on Windows

@johnmahugu
Copy link

johnmahugu commented Jul 16, 2024 via email

@jimklimov
Copy link

jimklimov commented Jul 16, 2024 via email

@7zmau
Copy link

7zmau commented Nov 9, 2024

curl also supports custom dns resolver. Use --resolve to specify target of this request.

curl https://your-website.com --resolve your-website.com:1.2.3.4:443

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment