# Cutehttpd **Repository Path**: dabinvip/Cutehttpd ## Basic Information - **Project Name**: Cutehttpd - **Description**: No description available - **Primary Language**: C - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2016-11-25 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README 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); }