一个好用且方便的FastCgi C++库 - FastCgi++

不知道你是不是曾经发愁过使用FastCgi库来使用C++开发Fastcgi程序繁琐而且会与C++ STL代码产生冲突的地方,或者你还是习惯了cout而不是pringf,那这篇文章就可以了解到一个使用的比较少的FastCgi 的C++库  —— FastCgi++ / FastCgipp。

开发环境:

  OS: Centos 7

  编译器:gcc 4.8.3

准备:

  1. 我的yum源中没有找到Fastcgi++,而且,正如我以往的习惯来说,我还是比较喜欢源码编译 : )

    FastCgi++ 官方介绍: http://www.nongnu.org/fastcgipp/

      下载 源码:最新版本为2.1版本 http://download.savannah.nongnu.org/releases/fastcgipp/fastcgi++-2.1.tar.bz2

  2.  国外大多数开源库中都会使用Boost库,所以,免不了需要安装libboost-devel。参考Mongodb中对Boost库的安装。或者直接yum install boost-devel,也就仅仅是依赖这一个非标准库,所以不需要安装其他。

  3.  由于是FastCgi Application ,选一个一个WebServer来验证他的执行成果。选择Nginx,我的Nginx版本为1.6.0

编译:

  1.  这一段确实也没什么好说的

      tar -xvjf fastcgi++-2.1.tar.bz2

      ./configure --disable-shared --enable-static

      make && make install

  再不指定prefix的路径的情况下,GCC编译也就会到默认的路径去寻找头文件与库文件。这里,我选择编译成了静态库的形式,不需要数据库有关的操作,不需要编译进去.

基本使用:

开始使用:

   

/** * Fastcgi++ Test by kk * main.cpp */

#include <boost/date_time/posix_time/posix_time.hpp>
#include <fstream>
#include <fastcgi++/request.hpp>
#include <fastcgi++/manager.hpp>
void error_log(const char* msg)
{
   using namespace std;
   using namespace boost;
   static ofstream error;
   if(!error.is_open())
   {
      error.open("/tmp/errlog", ios_base::out | ios_base::app);
      error.imbue(locale(error.getloc(), new posix_time::time_facet()));
   }
   error << ‘[‘ << posix_time::second_clock::local_time() << "] " << msg << endl;
}
class HelloWorld: public Fastcgipp::Request<wchar_t>
{
   bool response()
   {
      wchar_t russian[]={ 0x041f, 0x0440, 0x0438, 0x0432, 0x0435, 0x0442, 0x0020, 0x043c, 0x0438, 0x0440, 0x0000 };
      wchar_t chinese[]={ 0x4e16, 0x754c, 0x60a8, 0x597d, 0x0000 };
      wchar_t greek[]={ 0x0393, 0x03b5, 0x03b9, 0x03b1, 0x0020, 0x03c3, 0x03b1, 0x03c2, 0x0020, 0x03ba, 0x03cc, 0x03c3, 0x03bc, 0x03bf, 0x0000 };
      wchar_t japanese[]={ 0x4eca, 0x65e5, 0x306f, 0x4e16, 0x754c, 0x0000 };
      wchar_t runic[]={ 0x16ba, 0x16d6, 0x16da, 0x16df, 0x0020, 0x16b9, 0x16df, 0x16c9, 0x16da, 0x16de, 0x0000 };
      out << "Content-Type: text/html; charset=utf-8\r\n\r\n";
      out << "<html><head><meta http-equiv=‘Content-Type‘ content=‘text/html; charset=utf-8‘ />";
      out << "<title>fastcgi++: Hello World in UTF-8</title></head><body>";
      out << "English: Hello World<br />";
      out << "Russian: " << russian << "<br />";
      out << "Greek: " << greek << "<br />";
      out << "Chinese: " << chinese << "<br />";
      out << "Japanese: " << japanese << "<br />";
      out << "Runic English?: " << runic << "<br />";
      out << "</body></html>";
      err << "Hello apache error log";
      return true;
   }
};
int main()
{
   try
   {
      Fastcgipp::Manager<HelloWorld> fcgi;
      fcgi.handler();
   }
   catch(std::exception& e)
   {
      error_log(e.what());
   }
}

  使用GCC将其编译:g++ -o main -lboost_system-mt -lboost_thread-mt -lfastcgipp main.cpp

验证:

  由于是一个FastCgi程序,所以就需要一个lighthttpd项目中一个fastcgi启动器spawn-fastcgi(好吧,暂且先启动器这么叫,我想在下面的文章源码具体探索一下spawn-fastcgi的执行过程)

  网上关于spawn-fastcgi的教程很多,编译起来也不难。贴上源码下载路径就好:http://www.lighttpd.net/download/lighttpd-1.4.19.tar.gz

  更改Nginx配置文件 nginx.conf 在server中加入fastcgi配置:

  

location ~\.fcgi$ {
                        fastcgi_pass 127.0.0.1:9000;
                        fastcgi_index index.fcgi;
                        fastcgi_param SCRIPT_FILENAME /$fastcgi_script_name;
                        include fastcgi_params;
                }

  重启Nginx重新加载配置文件。

  运行spawn-fastcgi程序:  

    spawn-fastcgi -a 127.0.0.1 -C 20 -p 9000 main

  成功提示:spawn-fcgi: child spawned successfully: PID: 13404

  现在打开浏览器,输入localhost/test.fcgi就能看到C++代码输出的值了。

后记:

  以前一直使用的FastCgi库,但是这是一个C语言的库,用C++来开发使用极其不方便,而且会出现一些不知名的错误。FastCgi++使用OOP设计,能完美的使用C++来开发FastCgi程序。在后面的文章会详细的介绍FastCgi++的使用方法。 :)  工作愉快

时间: 2024-10-08 10:04:16

一个好用且方便的FastCgi C++库 - FastCgi++的相关文章

Numeral.js 是一个用于格式化和数字四则运算的js 库

1.Numeral.js 是一个用于格式化和数字四则运算的js 库. 2.支持多种语言,包含中文在内的17种语言. 在浏览器中引用js文件: <script src="numeral.min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/numeral.js/1.4.5/numeral.min.js"></script> 在nodejs开发引用开

[C#] BarcodeLib -- 一个精简而不失优雅的条形码生成库

BarcodeLib -- 一个精简而不失优雅的条形码生成库 引言 在百度进行“C# 条形码”等类似关键字搜索的时候,基本上是使用 ZXing 类库进行条形码的生成.今天我所介绍的是另一款类库 Barcode,一起来共同见证它的强大之处. 目录 插曲 官方介绍 Nuget 安装 支持的类型 简单使用 插曲 请先允许我娓娓道来一个凄美的故事. 有一对情侣,男的非常懦弱,做什么事情之前都让女友先试.女友对此十分不满.一次,两人出海,返航时,飓风将小艇摧毁,幸亏女友抓住了一块木板才保住了两人的性命.女

Bean-Query 一个把对象转换为Map的Java工具库

刚开源了一个经过完整测试的Java工具类.目前的代码已经经历了完整的测试,正在申请放到Maven central Repository上. 地址如下: https://github.com/Jimmy-Shi/bean-query 使用说明如下: Bean-query Click Here for English version. BeanQuery 是一个把对象转换为Map的Java工具库.支持选择Bean中的一些属性,对结果进行排序和按照条件查询.不仅仅可以作用于顶层对象,也可以作用于子对象

BarcodeLib -- 一个精简而不失优雅的条形码生成库

BarcodeLib -- 一个精简而不失优雅的条形码生成库 引言 在百度进行"C# 条形码"等类似关键字搜索的时候,基本上是使用 ZXing 类库进行条形码的生成.今天我所介绍的是另一款类库 Barcode,一起来共同见证它的强大之处. 目录 插曲 官方介绍 Nuget 安装 支持的类型 简单使用 插曲 请先允许我娓娓道来一个凄美的故事. 有一对情侣,男的非常懦弱,做什么事情之前都让女友先试.女友对此十分不满.一次,两人出海,返航时,飓风将小艇摧毁,幸亏女友抓住了一块木板才保住了两人

htpwdScan — 一个简单的HTTP暴力破解、撞库攻击脚本

李姐姐之前跟我们分享了子域名枚举工具subDomainBrute<subDomainsBrute — 改进渗透测试时暴力枚举子域名的python脚本>,这回带给我们htpwdScan htpwdScan 是一个简单的HTTP暴力破解.撞库攻击脚本: 1. 支持批量校验并导入HTTP代理,低频撞库可以成功攻击大部分网站,绕过大部分防御策略和waf2. 支持直接导入互联网上泄露的社工库,发起撞库攻击3. 支持导入超大字典4. 其他细微功能:随机X-Forwarded-For.随机SessionID

MapleBacon 是一个非常棒的图片下载和缓存库

http://www.oschina.net/ios/codingList/367/ios-image http://www.oschina.net/p/maplebacon MapleBacon 是一个非常棒的图片下载和缓存库,使用 Swift 开发,用于 iOS 系统. 示例代码: import MapleBacon @IBOutlet weak var imageView: UIImageView! if let imageURL = NSURL(string: "something.jp

一个非常好而且免费的CSS开发库Pure

一个非常好而且免费的CSS开发库Pure 一个非常好而且免费的CSS开发库,最近研究Pure,发现这个对于写css来说确实是个好的框架,特此总结了一番,如有错误或不足的地方,欢迎交流指点,轻拍. 此文运用的是优雅的Markdown而书 Pure学习笔记 #写在最前 1# Pure简介Pure的所有模块都是基于Normalize.css.Normalize能在一定程度上解决跨浏览器的一致性问题. 我们运用的Pure,其思想就是将你要布局的页面,尽量给网格化,这样复杂的页面在管理起来就更轻松.简单.

sandglass(沙漏)——一个让人解脱的python时间处理库

在游戏开发的过程中频繁的需要跟时间相关的做处理,而python内置了好多个时间处理库,datetime/date/time/calendar/timedelta等,细节繁多略具迷惑性.很多东西不够便捷直接. 想一下下面这些场景: 2014年六一儿童节那天的时间戳是多少? 2014年六一儿童节那天是星期几? datetime对象转成字符串后面往往带小数点,即微秒,而我存到数据库是不需要微秒的,怎么搞? 从配置中读取.网络中传输.数据库存储获取到的时间信息是字符串的,怎么转成可以用于运算的对象? 要

FastCGI模块(FastCGI)

这个模块允许nginx同FastCGI协同工作,并且控制哪些参数将被安全传递.例: location / { fastcgi_pass localhost:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /home/www/scripts/php$fastcgi_script_name; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METH