🥧 HTTPie CLI — modern, user-friendly command-line HTTP client for the API era. JSON support, colors, sessions, downloads, plugins & more.
Go to file
Mickaël Schoentgen 71adcd97d0
Improve handling of prettified responses without correct content-type encoding (#1110)
* Improve handling of responses without correct content-type charset

* [skip ci] Minor tweaks in tests

* [skip ci] Add documentation

Co-authored-by: claudiatd <claudiatd@gmail.com>

* Improve unknown encoding test

[skip ci]

* Review mime and options retrieval

* Add full content-type example in help output

* Simplify decoder

* [skip ci] s/charset/encoding/

* Tweaks

* [skip ci] Fix type annotation

* [skip ci] s/charset/encoding/

* Tweaks

* Fix type annoation

* Improvement

* Introduce `codec.encode()`

* [skip ci] Tweak changelog

Co-authored-by: claudiatd <claudiatd@gmail.com>
2021-09-29 20:22:19 +02:00
.github Add workflow to test with pyOpenSSL active (#1164) 2021-09-23 10:37:23 +02:00
docs Improve handling of prettified responses without correct content-type encoding (#1110) 2021-09-29 20:22:19 +02:00
extras Update brew formula to 2.5.0 (#1144) 2021-09-08 11:01:27 +02:00
httpie Improve handling of prettified responses without correct content-type encoding (#1110) 2021-09-29 20:22:19 +02:00
tests Improve handling of prettified responses without correct content-type encoding (#1110) 2021-09-29 20:22:19 +02:00
.editorconfig Update links to HTTPS 2019-08-30 10:07:01 +02:00
.gitignore Add a Packit configuration for Fedora packaging (#1086) 2021-06-09 17:18:27 +02:00
.packit.yaml Packit: Get the current Fedora Rawhide specfile 2021-09-07 11:03:04 +02:00
AUTHORS.md Switch from reStructuredText to Markdown and add docs/ (#1139) 2021-09-06 17:36:13 +02:00
CHANGELOG.md Improve handling of prettified responses without correct content-type encoding (#1110) 2021-09-29 20:22:19 +02:00
CODE_OF_CONDUCT.md Add a workflow to check documentations (#1151) 2021-09-09 15:52:24 +02:00
CONTRIBUTING.md Add a workflow to check documentations (#1151) 2021-09-09 15:52:24 +02:00
LICENSE 2021 2021-02-06 13:29:02 +01:00
Makefile Expand the pytest configuration (#1161) 2021-09-20 17:36:03 +02:00
MANIFEST.in Switch from reStructuredText to Markdown and add docs/ (#1139) 2021-09-06 17:36:13 +02:00
README.md Update README.md 2021-09-10 11:17:23 +02:00
setup.cfg Expand the pytest configuration (#1161) 2021-09-20 17:36:03 +02:00
setup.py Improve handling of prettified responses without correct content-type encoding (#1110) 2021-09-29 20:22:19 +02:00
snapcraft.yaml [snap] Improve OS integration (#1157) 2021-09-15 16:50:44 +02:00


HTTPie

HTTPie: human-friendly CLI HTTP client for the API era

HTTPie (pronounced aitch-tee-tee-pie) is a command-line HTTP client. Its goal is to make CLI interaction with web services as human-friendly as possible. HTTPie is designed for testing, debugging, and generally interacting with APIs & HTTP servers. The http & https commands allow for creating and sending arbitrary HTTP requests. They use simple and natural syntax and provide formatted and colorized output.

Docs Latest version Build Coverage Twitter Chat

HTTPie in action

Getting started

Features

  • Expressive and intuitive syntax
  • Formatted and colorized terminal output
  • Built-in JSON support
  • Forms and file uploads
  • HTTPS, proxies, and authentication
  • Arbitrary request data
  • Custom headers
  • Persistent sessions
  • wget-like downloads

See all features →

Examples

Hello World:

$ https httpie.io/hello

Custom HTTP method, HTTP headers and JSON data:

$ http PUT pie.dev/put X-API-Token:123 name=John

Build and print a request without sending it using offline mode:

$ http --offline pie.dev/post hello=offline

Use GitHub API to post a comment on an Issue with authentication:

$ http -a USERNAME POST https://api.github.com/repos/httpie/httpie/issues/83/comments body='HTTPie is awesome! :heart:'

See more examples →

Community & support

Contributing

Have a look through existing Issues and Pull Requests that you could help with. If you'd like to request a feature or report a bug, please create a GitHub Issue using one of the templates provided.

See contribution guide →