Git Product home page Git Product logo

cutehttpd's Introduction

Cutehttpd - 嵌入式 HTTP 服务器

Cutehttpd 是用纯 C 写的一个小巧的嵌入式 http 服务器。Cutehttpd 尽可能将协议分化为对象类,这使得上一层的开发变得更容易,上层调用只需考虑逻辑处理。无请求状态下约占用 2MB 内存,1000 个请求约占用 4MB 内存。可执行文件体积约为 70KB。

特性

  • 支持 FastCGI;
  • URI 钩子,指定 URI 绑定到指定函数处理;
  • 目录列表;
  • MIME Type。

计划

  • 支持 SSL;
  • 动态加载符合标准 JSON 的配置文件。

应用

远程控制面板,以及其他基于 Web 的产品开发。

协议

使用 GNU Lesser General Public License v3.0 协议发布。 简而言之,链接到 Cutehttpd 库的产品可以不公开源代码,但是对 Cutehttpd 源码进行修改必须公开源代码,并使用 LGPL 协议发布。

状态

基本成形,可以尝试进行二次开发。 欢迎提出建议 YinzCN_@_gmail.com

示例

Cutehttpd 将支持多种编程语言,包括 C/C++, Ruby, Lua, C#

下面用 C 语言演示了将如何使用 Cutehttpd:

#include "../src/cutehttpd.c"

int
main(int argc, char *argv[])
{
  /*
    创建一个服务器对象 htdx
    可用 void * 或者 int 保存,其他语言或许可以用一个整数类型。
    可以同时创建多个 htdx,绑定到不同的端口进行服务。
  */
  void *htdx;
  htdx = htd_create();

  /*
    基本配置
  */
  htd_set_opt  (htdx, "addr", "127.0.0.1");   /* http 绑定服务地址 */
  htd_set_opt  (htdx, "port", "8080");        /* http 绑定服务端口 */
  htd_set_opt  (htdx, "max_workers", "1000"); /* 最大工作线程数, 决定最大并发请求 */
  htd_set_opt  (htdx, "keep_alive", "15");    /* 设置 keep_alive 超时, 0 禁用; */
  htd_set_opt  (htdx, "max_post_size", "8M"); /* 最大 POST 数据; */

  /*
    设置 fastcgi
    htd_set_fcgi (htdx, ".扩展", "地址", "端口", "[启动命令行]");
    若存在 [启动命令行],htdx 将自动管理 fcgi 进程。
  */
  htd_set_fcgi (htdx, ".php", "127.0.0.1", "9000", "php\\php-cgi.exe -b @addr@:@port@");

  /*
    虚拟主机
    htd_set_vhost(htdx, "主机名", "根目录");
  */
  htd_set_vhost(htdx, "127.0.0.10", "./vhosts/host1", "1");
  htd_set_vhost(htdx, "127.0.0.20", "./vhosts/host2", "1");
  htd_set_vhost(htdx, "127.0.0.30", "./vhosts/host3", "1");
  /*
    默认虚拟主机
  */
  htd_set_vhost(htdx, "*", "htdocs", "1");

  /*
    URI 钩子,嵌入式的主要实现
    htd_set_xhook(htdx, "HostName", "URI", *FuncAddr);
    如果一个请求(Host与URI)匹配一个钩子, 将调用FuncAddr的函数
    注意: URI 使用正则表达式, 而主机名直接完整匹配
  */
  htd_set_xhook(htdx, "127.0.0.1", "/any/.*", xhook_test_1);
  htd_set_xhook(htdx, "127.0.0.1", "/server-status", server_status);
  htd_set_xhook(htdx, "127.0.0.1", "/xhook2-2", xhook_test_2);
  /*
    匹配任意主机
  */
  htd_set_xhook(htdx, "*", "/xhook2", xhook_test_2);

  /*
    启动 cutehttpd 服务
    cutehttpd 将会在内部创建线程运行
  */
  int Retn;
  Retn = htd_start(htdx);
  if (Retn) /* 成功返回 1 */
  {
    printf("cutehttpd 启动成功。");
  } else {
    printf("cutehttpd 启动失败!");
  }

  while (1) {
    /*
      [你的程序代码]
    */
    Sleep(20);
  }

  /*
    停止 ctuehttpd
  */
  htd_stop(htdx);

}

cutehttpd's People

Contributors

jonavery avatar yinzcn avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.