cpp-httplib =========== A C++11 header-only HTTP library. It's extremely easy to setup. Just include **httplib.h** file in your code! Inspired by [Sinatra](http://www.sinatrarb.com/) and [express](https://github.com/visionmedia/express). Server Example -------------- ```c++ #include int main(void) { using namespace httplib; Server svr; svr.Get("/hi", [](const Request& req, Response& res) { res.set_content("Hello World!", "text/plain"); }); svr.Get(R"(/numbers/(\d+))", [&](const Request& req, Response& res) { auto numbers = req.matches[1]; res.set_content(numbers, "text/plain"); }); svr.listen("localhost", 1234); } ``` `Post`, `Put`, `Delete` and `Options` methods are also supported. ### Method Chain ```cpp svr.Get("/get", [](const auto& req, auto& res) { res.set_content("get", "text/plain"); }) .Post("/post", [](const auto& req, auto& res) { res.set_content(req.body(), "text/plain"); }) .listen("localhost", 1234); ``` ### Static File Server ```cpp svr.set_base_dir("./www"); ``` ### Logging ```cpp svr.set_logger([](const auto& req, const auto& res) { your_logger(req, res); }); ``` ### Error Handler ```cpp svr.set_error_handler([](const auto& req, auto& res) { const char* fmt = "

Error Status: %d

"; char buf[BUFSIZ]; snprintf(buf, sizeof(buf), fmt, res.status); res.set_content(buf, "text/html"); }); ``` ### 'multipart/form-data' POST data ```cpp svr.Post("/multipart", [&](const auto& req, auto& res) { auto size = req.files.size(); auto ret = req.has_file("name1")); const auto& file = req.get_file_value("name1"); // file.filename; // file.content_type; auto body = req.body.substr(file.offset, file.length)); }) ``` Client Example -------------- ### GET ```c++ #include #include int main(void) { httplib::Client cli("localhost", 1234); auto res = cli.Get("/hi"); if (res && res->status == 200) { std::cout << res->body << std::endl; } } ``` ### POST ```c++ res = cli.Post("/post", "text", "text/plain"); res = cli.Post("/person", "name=john1¬e=coder", "application/x-www-form-urlencoded"); ``` ### POST with parameters ```c++ httplib::Params params; params.emplace("name", "john"); params.emplace("note", "coder"); auto res = cli.Post("/post", params); ``` or ```c++ httplib::Params params{ { "name", "john" }, { "note", "coder" } }; auto res = cli.Post("/post", params); ``` ### PUT ```c++ res = cli.Put("/resource/foo", "text", "text/plain"); ``` ### DELETE ```c++ res = cli.Delete("/resource/foo"); ``` ### OPTIONS ```c++ res = cli.Options("*"); res = cli.Options("/resource/foo"); ``` ### Connection Timeout ```c++ httplib::Client cli("localhost", 8080, 5); // timeouts in 5 seconds ``` ### With Progress Callback ```cpp httplib::Client client(url, port); // prints: 0 / 000 bytes => 50% complete std::shared_ptr res = cli.Get("/", [](uint64_t len, uint64_t total) { printf("%lld / %lld bytes => %d%% complete\n", len, total, (int)((len/total)*100)); } ); ``` ![progress](https://user-images.githubusercontent.com/236374/33138910-495c4ecc-cf86-11e7-8693-2fc6d09615c4.gif) This feature was contributed by [underscorediscovery](https://github.com/yhirose/cpp-httplib/pull/23). ### Range ```cpp httplib::Client cli("httpbin.org", 80); // 'Range: bytes=1-10' httplib::Headers headers = { httplib::make_range_header(1, 10) }; auto res = cli.Get("/range/32", headers); // res->status should be 206. // res->body should be "bcdefghijk". ``` OpenSSL Support --------------- SSL support is available with `CPPHTTPLIB_OPENSSL_SUPPORT`. `libssl` and `libcrypto` should be linked. ```c++ #define CPPHTTPLIB_OPENSSL_SUPPORT SSLServer svr("./cert.pem", "./key.pem"); SSLClient cli("localhost", 8080); ``` Zlib Support ------------ 'gzip' compression is available with `CPPHTTPLIB_ZLIB_SUPPORT`. The server applies gzip compression to the following MIME type contents: * all text types * image/svg+xml * application/javascript * application/json * application/xml * application/xhtml+xml License ------- MIT license (© 2018 Yuji Hirose)