cinatra发布第一个版本

cinatra–a sinatra inspired modern c++ web framework

cinatra是什么?

cinatra是C++开源社区–purecpp发起的一个开源项目,现在正式发布第一个版本cinatra0.9.0,cinatra是一个现代C++写的web framework,它的目的是给用户提供一个易用、灵活和高性能的web框架,让用户能完全专注于核心逻辑而无需关注http细节。它的灵感来源于sinatra,但又有自己的特色。

如何使用

1.从github上下载源码。

2.安装boost,因为框架用到asio和coroutine,需要1.57及以上的版本。

3.编译。已经提供vs2013的工程文件和Cmakelist,直接在win和linux平台下编译即可。

示例

运行起来之后,在浏览器中输入:127.0.0.1就可以看到返回的” Hello Cinatra”, 用起来是不是很简单,cinatra框架帮你把很多事情都做好了,你只需要关注你的核心业务逻辑即可。让我们继续看一个稍微复杂一点的例子。

浏览器中输入:127.0.0.1/hello?name=test&age=12,页面将输出” Hello test”。 为了让用户用起来更方便,我们还支持下面这种url请求方式:127.0.0.1/hello/test/12,这个url将会被路由到”/hello/:name/:age”对应的handler:[](Request& req, Response& res, const std::string& a, int b);

Router不仅仅支持lambda表达式还支持类的成员函数,如果你想把handler放到类对象中,你可以这样做。

cinatra不仅仅使用简单,还很灵活,它支持AOP,我们可以很方便的将非核心逻辑和核心逻辑分离,比如下面的例子。

上面的例子中我们增加了一个检查是否登录的切面,如果用户没登录将会重定向到登录页面。我们还可以自由组合多个切面,cinatra可以很方便地扩展任意多个切面。你可以这样扩展切面。

性能

用ab工具和另外一个c++ web框架crow做了一下性能对比:

crow:

crow test_看图王

cinatra:

cinatra test_看图王

可以看到cinatra比crow的性能略高。现在第一个版本还没有专门去做优化,主要是完成了基本功能,后续会持续优化的,也欢迎大家帮忙做进一步的性能测试。

cinatra的设计

cinatra的设计非常简单,只有几个组件,下面是cinatra的逻辑视图。

图片1

用户仅用cinatra即可,其它的事情框架已经帮用户做好了,用户只用关注核心逻辑即可,这些核心逻辑都在handler中处理,而这些handler完全由用户自定义和扩展。

roadmap

目前支持了http1.0和1.1,支持了session和cookie,后续计划:

  • https
  • html模板
  • websocket
  • cinatra打造purecpp社区

开发和参与者

C++开源社区:http://purecpp.org/,江南,网事如风,SIGSEGV,海盗,福尔摩斯喵。

更多的例子请到社区github上看。

如果你发现了问题请及时到社区反馈给我们,也欢迎提出宝贵意见。希望更多的人能参与进来。

如果你觉得cinatra不错,请不要吝惜给一个star^_^。

《cinatra发布第一个版本》有23个想法

  1. 用VS2013打开sln 编译hello_world之后 有运行时错误
    Unhandled exception at 0x75CFC42D in hello_world.exe: Microsoft C++ exception: boost::exception_detail::clone_impl<boost::exception_detail::error_info_injector > at memory location 0x0032F3D0.
    请问这个什么原因呢

  2. 在ubuntu下 g++ 4.8.4编译报错
    In file included from /cinatra/examples/hello_world/main.cpp:1:0:
    /cinatra/examples/hello_world/../../include/cinatra/cinatra.hpp: In constructor ‘cinatra::Cinatra::Cinatra()’:
    /cinatra/examples/hello_world/../../include/cinatra/cinatra.hpp:21:8: error: conversion from ‘const char [9]’ to non-scalar type ‘std::string {aka std::basic_string}’ requested
    class Cinatra
    ^
    /cinatra/examples/hello_world/main.cpp: In function ‘int main()’:
    /cinatra/examples/hello_world/main.cpp:5:21: note: synthesized method ‘cinatra::Cinatra::Cinatra()’ first required here
    cinatra::Cinatra app;
    ^

      1. 你好,我下载的是最新的代码,并且按照你们给的步骤编译的,http_sever这个例子可以编译过,可是其它的就不行,就报我说的那个错误

          1. 不好意思,才看到,新代码可以编译通过了,请问之前的代码为什么会出现那样的编译错误啊,是编译器的问题吗?谢谢!

  3. 个人建议该项目后继加上模板功能,使HTML文件中可以嵌入C++或者其它脚本语言代码,这样可更方便的分离前端和后端的功能。

  4. hi 我的环境是cygwin+gcc 5.4.0
    编译的时候有很多boost asio模块的报错.

    (long int*)和类型(volatile int *)不匹配.
    asio中有很多函数参数类型是后者,但是入参是前者.

    查了一圈,没有找到添加什么编译器选项解决此问题.

发表评论