2025-03-14 21:59:59 -06:00
|
|
|
# xh
|
|
|
|
|
|
|
|
|
|
> Friendly and fast tool for sending HTTP requests.
|
|
|
|
|
> Note: `xh`, written in rust, serves as an effective drop-in replacement for `http`.
|
|
|
|
|
> See also: `http`, `curl`.
|
|
|
|
|
> More information: <https://github.com/ducaale/xh>.
|
|
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
- Send a GET request (shows response headers and content):
|
2025-03-14 21:59:59 -06:00
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
`xh {{https://postman-echo.com/get}}`
|
2025-03-14 21:59:59 -06:00
|
|
|
|
|
|
|
|
- Send a POST request with a JSON body (key-value pairs are added to a top-level JSON object - e.g. `{"name": "john", "age": 25}`):
|
|
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
`xh post {{https://postman-echo.com/post}} {{name=john}} {{age=25}}`
|
2025-03-14 21:59:59 -06:00
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
- Send a GET request with query parameters (e.g. `https://postman-echo.com/response-headers?foo1=bar1&foo2=bar2`):
|
2025-03-14 21:59:59 -06:00
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
`xh get {{https://postman-echo.com/response-headers}} {{foo1==bar1}} {{foo2==bar2}}`
|
2025-03-14 21:59:59 -06:00
|
|
|
|
|
|
|
|
- Send a GET request with a custom header:
|
|
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
`xh get {{https://postman-echo.com}} {{header-name:header-value}}`
|
2025-03-14 21:59:59 -06:00
|
|
|
|
|
|
|
|
- Make a GET request and save the response body to a file:
|
|
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
`xh {{[-d|--download]}} {{https://example.com}} {{[-o|--output]}} {{path/to/file}}`
|
|
|
|
|
|
|
|
|
|
- Construct a request but do not send it (similar to a dry-run):
|
|
|
|
|
|
|
|
|
|
`xh --offline {{get|delete|...}} {{https://example.com}}`
|
2025-03-14 21:59:59 -06:00
|
|
|
|
|
|
|
|
- Show equivalent `curl` command (this will not send any request):
|
|
|
|
|
|
2025-06-28 19:25:29 -06:00
|
|
|
`xh --{{curl|curl-long}} {{--follow --verbose get https://example.com user-agent:curl}}`
|