RESTINIO هي مكتبة C ++ 17 تمنحك خادم HTTP/WebSocket مضمن. يعتمد على النسخة المستقلة من ASIO ويستهدف في المقام الأول للمعالجة غير المتزامنة لمقالات HTTP. Boost :: Asio مدعوم أيضا.
Restinio نفسها هي مكتبة رأس فقط ، ولكنها تعتمد على NodeJS/LLHTTP التي ليست رأسًا فقط.
RESTINIO حاليًا في حالة مستقرة إلى حد ما ، ونحن نعتقد أنه منذ الإصدار v.0.4.0 فهي جاهزة للاستخدام الإنتاج.
النظر في مهمة كتابة تطبيق C ++ الذي يجب أن يدعم بعض API REST ، تمثل Restinio حلنا لهذه المهمة.
لنرى كيف يبدو الأمر في أبسط الحالات:
# include < restinio/core.hpp >
int main ()
{
restinio::run (
restinio::on_this_thread ()
. port ( 8080 )
. address ( " localhost " )
. request_handler ([]( auto req) {
return req-> create_response (). set_body ( " Hello, World! " ). done ();
}));
return 0 ;
}يعمل الخادم على الموضوع الرئيسي ، ويستجيب لجميع الطلبات باستخدام رسالة Hello-World. بالطبع لديك وصول إلى بنية طلب HTTP معين ، بحيث يمكنك تطبيق منطق معقد للتعامل مع طلبات التعامل معها.
# include < restinio/core.hpp >
using namespace restinio ;
template < typename T>
std::ostream & operator <<(std::ostream & to, const optional_t <T> & v) {
if (v) to << *v;
return to;
}
int main () {
// Create express router for our service.
auto router = std::make_unique<router:: express_router_t <>>();
router-> http_get (
R"( /data/meter/:meter_id(d+) )" ,
[]( auto req, auto params) {
const auto qp = parse_query (req-> header (). query ());
return req-> create_response ()
. set_body (
fmt::format ( " meter_id={} (year={}/mon={}/day={}) " ,
cast_to< int >(params[ " meter_id " ]),
opt_value< int >(qp, " year " ),
opt_value< int >(qp, " mon " ),
opt_value< int >(qp, " day " )))
. done ();
});
router-> non_matched_request_handler (
[]( auto req){
return req-> create_response ( restinio::status_not_found ()). connection_close (). done ();
});
// Launching a server with custom traits.
struct my_server_traits : public default_single_thread_traits_t {
using request_handler_t = restinio::router:: express_router_t <>;
};
restinio::run (
restinio::on_this_thread<my_server_traits>()
. address ( " localhost " )
. request_handler ( std::move (router)));
return 0 ;
}يتم توزيع Restinio بموجب ترخيص BSD-3-Cause.
يمكن العثور على الوثائق الكاملة لـ Restinio هنا.