thttpd源码分析-----http协议头部检测

在源码中,用于http 头部检测的是 httpd_got_request 函数

该函数并没有检测头部的内容,只是检测头部的格式而已,最明显的格式检测就是 \r\n ,空格,tab符 ,即http协议中,头部的每一行都用 \r\n 结尾,在行中,每一词用空格或tab符分开 ,说明更简单一些,就是检查请求行是不是有三个words,头部结束是不是以空行结束 。仅此而已

下面是用的几种状态来检测格式是否合法的

/* Checks hc->read_buf to see whether a complete request has been read so far;
 ** either the first line has two words (an HTTP/0.9 request), or the first
 ** line has three words and there's a blank line present.
 **
 ** hc->read_idx is how much has been read in; hc->checked_idx is how much we
 ** have checked so far; and hc->checked_state is the current state of the
 ** finite state machine.
 */
int httpd_got_request(httpd_conn* hc) {
	char c;

	for (; hc->checked_idx < hc->read_idx; ++hc->checked_idx) {
		c = hc->read_buf[hc->checked_idx];
		switch (hc->checked_state) {
		cas
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以帮你实现这个功能。首先,我们需要明确一下 thttpd-cgi 接口是什么。thttpd 是一个非常轻量级的 HTTP 服务器,而 thttpd-cgi 则是用来处理 CGI 请求的模块。在 thttpd-cgi 中,我们可以通过解析 HTTP 请求的参数和数据来处理 CGI 请求,并返回相应的响应。 为了实现清空网页内容的功能,我们可以编写一个简单的 CGI 程序,将其部署在 thttpd-cgi 中。具体实现方式如下: 1. 编写 CGI 程序的源码,可以使用 C/C++、Python、Perl 等语言实现。下面是一个 Python 实现的示例代码: ```python #!/usr/bin/env python # -*- coding: utf-8 -*- print("Content-type:text/html") print("") print(""" <html> <head> <title>清空网页内容</title> </head> <body> <script> document.body.innerHTML = ""; </script> <h1>网页内容已清空</h1> </body> </html> """) ``` 2. 将上述代码保存为一个 Python 文件,如 `clear.py`。 3. 将 `clear.py` 文件部署到 thttpd-cgi 的 CGI 目录中,例如 `/var/www/cgi-bin/` 目录。 4. 在 thttpd 的配置文件中添加以下配置: ``` dir cgi-bin { cgi ".py=/usr/bin/python3" } ``` 这个配置告诉 thttpd-cgi,当请求以 `.py` 结尾时,使用 `/usr/bin/python3` 解释器来执行 CGI 程序。 5. 重启 thttpd 服务器,使配置生效。 现在,当你访问 `http://<服务器IP>/cgi-bin/clear.py` 时,就会执行上述 Python 程序,清空网页内容,并在页面上显示“网页内容已清空”的文字。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值