C语言一个吓用都方便之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++的施用方式。
🙂  工作愉快