https://github.com/httpie/httpcat
  
  
     httpcat is a simple utility for constructing raw HTTP requests on the command line.  
    https://github.com/httpie/httpcat
  
api api-testing cli command-line debugging http httpie python terminal utility
        Last synced: 7 months ago 
        JSON representation
    
httpcat is a simple utility for constructing raw HTTP requests on the command line.
- Host: GitHub
- URL: https://github.com/httpie/httpcat
- Owner: httpie
- License: other
- Created: 2016-12-12T17:14:03.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2024-10-31T22:38:55.000Z (12 months ago)
- Last Synced: 2024-10-31T23:25:17.339Z (12 months ago)
- Topics: api, api-testing, cli, command-line, debugging, http, httpie, python, terminal, utility
- Language: Python
- Homepage: https://httpie.io
- Size: 25.4 KB
- Stars: 227
- Watchers: 11
- Forks: 29
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
- Funding: .github/FUNDING.yml
 
Awesome Lists containing this project
README
          # `httpcat`
[](https://github.com/jakubroztocil/httpcat/actions)
``httpcat`` is a simple utility for constructing raw HTTP
requests on the command line.
## Why?
Sometimes it is useful to be able to create an actual raw 
[HTTP request](https://www.w3.org/Protocols/rfc2616/rfc2616-sec5.html)
on the  command line:
 
* To debug a server issue
* To test the handling of invalid HTTP requests
* To learn how HTTP works under the hood
In such cases, existing CLI HTTP clients—such as 
[`httpie`](https://httpie.org),
[`curl`](https://curl.haxx.se/), 
or [`wget`](https://www.gnu.org/software/wget/) 
—are too high-level as they provide
an abstraction layer and one doesn't have a complete control over the 
exact raw data that gets written to the HTTP socket connection.
Lower-level tools, such as the popular 
[`netcat`](https://en.wikipedia.org/wiki/Netcat), are better suited for this 
job.
However, the syntax of HTTP requires headers to be separated with 
`\r\n` which makes it difficult to produce them on the command line. 
A typical solution involves the use of `echo`:
```bash
$ echo -ne 'POST /post HTTP/1.1\r\nHost: httpbin.org\r\nContent-Length: 5\r\n\r\nHello' | \
    nc localhost 8000
```
`httpcat` makes this easier:
## How it works
1. Reads command arguments as lines and then lines from ``stdin``
2. Auto-completes them, if necessary
3. Writes them to ``stdout``
## Features
* Automatic ``\r\n`` completion
* Automatic `Method` completion in `Request-Line`
* Automatic `HTTP-Version` completion in `Request-Line`
## Usage
Interactively create a request and send it with `nc`:
```bash
$ httpcat -v | nc httpbin.org 80
POST /post HTTP/1.1
> POST /post HTTP/1.1\r\n
Host: httpbin.org
> Host: httpbin.org\r\n
Content-Length: 6
> Content-Length: 6\r\n
> \r\n
Hello
> Hello
```
Specify the whole request in the arguments. Here `''` represents an empty
line which will be converted to `\r\n\` separating the headers and the 
body. Note also that the omitted `HTTP-Version` is auto-completed:
```bash
$ httpcat -v 'POST /post' 'Host: httpbin.org' 'Content-Length: 5' '' 'Hello'  | nc httpbin.org 80
> POST /post HTTP/1.1\r\n
> Host: httpbin.org\r\n
> Content-Length: 5\r\n
> \r\n
> Hello
```
Omitted `Method` is set to `GET` and `HTTP-Version` is auto-completed:
```bash
$ httpcat -v / 'Host: example.org' '' | nc example.org 80
> GET / HTTP/1.1\r\n
> Host: example.org\r\n
> \r\n
```
You can, for example, use `stdin` for data and arguments for headers: 
```bash
$ cat file.txt | httpcat -v 'POST /post' 'Host: httpbin.org' 'Content-Length: 16' '' | nc httpbin.org 80
> POST /post HTTP/1.1\r\n
> Host: httpbin.org\r\n
> Content-Length: 16\r\n
> \r\n
> Hello from file
```
See also `httpcat --help`:
```
usage: httpcat [-h] [-V, --version] [-v] [-n] [line [line ...]]
Create raw HTTP requests on the command line.
positional arguments:
  line            input lines read before lines from stdin
optional arguments:
  -h, --help      show this help message and exit
  -V, --version   show program's version number and exit
  -v, --verbose   print info about output lines to stderr
  -n, --no-stdin  disable reading of lines from stdin
```
## Dependencies
* Python 3
## Installation
```bash
pip3 install httpcat
```
Alternatively, you can just download `httpcat.py` manually and invoke 
it as `./httpcat.py` instead of `httpcat`. 
## Tests
```bash
python3 setup.py test
```
## HTTPie offline mode
[HTTPie CLI](https://httpie.io/) starting with version 2.0.0 also provides an [`--offline` mode](https://httpie.io/docs/cli/offline-mode). This makes it a good alternative to `httpcat` because it provides a convenient mechanism for crafting arbitrary HTTP requests without sending them using the user-friendly HTTPie syntax, for example:
```bash
echo -n 'Hello' | http --offline POST httpbin.org/post
```
The above command generates the following output:
```http
POST /post HTTP/1.1
Accept: application/json, */*;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Length: 5
Content-Type: application/json
Host: httpbin.org
User-Agent: HTTPie/2.2.0
Hello
```
The output is valid HTTP, so it can simply be sent using `nc`:
```bash
$ echo -n 'Hello' | http --offline POST httpbin.org/post | nc httpbin.org 80
```
## Changelog
* `0.0.2` (2016-12-13)
    * Added `-v, --verbose` and the command is more quiet by default.
    * Added `-n, --no-stdin`
    * Added `-h, --help` 
    * Added `-V, --version`
* `0.0.1` (2016-12-12)
   * Initial release.
## Contact
Jakub Roztocil
* [https://github.com/jkbrzt](https://github.com/jkbrzt)
* [https://twitter.com/jkbrzt](https://twitter.com/jkbrzt)
* [http://roztocil.co](http://roztocil.co)