当前位置: 首页 > news >正文

Lighttpd CGI配置:404错误排查实录

目录

引言

编写测试程序

前端代码

后端代码

配置CGI模块(mod_cgi)

如何检查404错误

测试结果

​编辑

结语


引言

在前面的测试中,我们将lighttpd移植到x210开发板中,今天学生报告说她在进行CGI程序测试时总是遭遇404错误。所谓404错误,就是服务器在处理CGI程序时总是找不到对应的脚本文件。针对这个问题进行了一番测试,介绍一下处理方法。

编写测试程序

前端代码

前端测试代码是这样的,用于调用 CGI 脚本:

<html>
<head><title>CGI测试页面</title><meta charset="UTF-8">
</head>
<body><h1>Lighttpd CGI测试</h1><h2>测试CGI脚本</h2><p><a href="/cgi-bin/test.cgi">运行测试CGI脚本</a></p><h2>带参数测试</h2><form action="/cgi-bin/test.cgi" method="get"><label>姓名: <input type="text" name="name"></label><label>年龄: <input type="number" name="age"></label><input type="submit" value="提交"></form><h2>POST方法测试</h2><form action="/cgi-bin/test.cgi" method="post"><label>消息: <textarea name="message"></textarea></label><input type="submit" value="发送"></form>
</body>
</html>

将这个 HTML 页面保存为/var/lighttpd/htdocs/test-cgi.html。 

后端代码

下面是一个基于 Bash 的测试 CGI 脚本,它会输出当前环境变量和请求信息:

#!/bin/bash# 输出HTTP头部
echo "Content-Type: text/html"
echo ""# 输出HTML页面
cat << EOF
<!DOCTYPE html>
<html>
<head><title>CGI测试</title><meta charset="UTF-8">
</head>
<body><h1>CGI脚本测试成功!</h1><p>当前时间: $(date)</p><h2>环境变量</h2><pre>
$(env | sort)</pre><h2>请求信息</h2><p>请求方法: $REQUEST_METHOD</p><p>请求URI: $REQUEST_URI</p><p>查询字符串: $QUERY_STRING</p>
</body>
</html>
EOF

把上述脚本保存为/var/lighttpd/cgi-bin/test.cgi(这里的路径有问题,后面会详细讲),并赋予执行权限: 

chmod +x /var/lighttpd/cgi-bin/test.cgi

配置CGI模块(mod_cgi)

使用CGI功能,要对 lighttpd 进行配置,使其支持 CGI 功能。找到并编辑 lighttpd 的modules配置文件,我们的配置为/var/lighttpd/config/modules.conf,取消include "conf.d/cgi.conf"这行前面的注释:

这样修改之后就可以激活mod_cgi。

然后修改/var/lighttpd/config/conf.d/cgi.conf文件,以指定 Bash 脚本作为 CGI 处理程序。

#######################################################################
##
##  CGI modules
## ---------------
##
## http://www.lighttpd.net/documentation/cgi.html
##
server.modules += ( "mod_cgi" )##
## Plain old CGI handling
##
## For PHP don't forget to set cgi.fix_pathinfo = 1 in the php.ini.
##
cgi.assign                 = ( ".pl"  => "/usr/bin/perl",".cgi" => "/bin/bash",".rb"  => "/usr/bin/ruby",".erb" => "/usr/bin/eruby",".py"  => "/usr/bin/python" )

保存设置后,启动lighttpd。如果先前已经启动了lighttpd ,需要先用kill杀掉lighttpd进程。

如何检查404错误

不过如果安装上述配置运行测试程序,会报告404文件错误,就是学生遇到的问题。

为了解决这个问题,我使用strace程序。这是一个强大的 Linux 系统调用跟踪工具,它能够监控和记录程序执行时所发起的系统调用以及收到的信号。

使用如下命令:

 strace  -e trace=file ./sbin/lighttpd -f config/lighttpd.conf -D

其中-e trace=file参数只跟踪与文件操作相关的系统调用,像 openreadwrite 等。 而-D参数是lighttpd的参数,表示程序不会切换到后台。程序运行后会输出下面的log:


stat64("/var/lighttpd/htdocs", {st_mode=S_IFDIR|0777, st_size=1024, ...}) = 0
open("/var/lighttpd/lib/mod_indexfile.so", O_RDONLY|O_CLOEXEC) = 3
fstat64(3, {st_mode=S_IFREG|0755, st_size=32008, ...}) = 0
open("/var/lighttpd/lib/mod_access.so", O_RDONLY|O_CLOEXEC) = 3
fstat64(3, {st_mode=S_IFREG|0755, st_size=30268, ...}) = 0
open("/var/lighttpd/lib/mod_cgi.so", O_RDONLY|O_CLOEXEC) = 3
fstat64(3, {st_mode=S_IFREG|0755, st_size=73015, ...}) = 0
open("/var/lighttpd/lib/mod_accesslog.so", O_RDONLY|O_CLOEXEC) = 3
fstat64(3, {st_mode=S_IFREG|0755, st_size=51523, ...}) = 0
open("/var/lighttpd/lib/mod_dirlisting.so", O_RDONLY|O_CLOEXEC) = 3
fstat64(3, {st_mode=S_IFREG|0755, st_size=59028, ...}) = 0
open("/var/lighttpd/lib/mod_staticfile.so", O_RDONLY|O_CLOEXEC) = 3
fstat64(3, {st_mode=S_IFREG|0755, st_size=42913, ...}) = 0
open("/var/lighttpd/lighttpd.pid", O_WRONLY|O_CREAT|O_EXCL|O_TRUNC|O_LARGEFILE, 0644) = 3
open("/var/lighttpd/log/error.log", O_WRONLY|O_CREAT|O_APPEND|O_LARGEFILE, 0644) = 3
open("/etc/localtime", O_RDONLY|O_CLOEXEC) = -1 ENOENT (No such file or directory)
open("/var/lighttpd/log/access.log", O_WRONLY|O_CREAT|O_APPEND|O_LARGEFILE, 0644) = 5
open("/dev/null", O_RDONLY|O_LARGEFILE) = 7
stat64("/var/lighttpd/htdocs/cgi-bin/test.cgi", 0xbed491b0) = -1 ENOENT (No such file or directory)

我发现,当运行test.cgi时,lighttpd去照相的文件是/var/lighttpd/htdocs/cgi-bin/test.cgi,而不是前面所想象的/var/lighttpd/cgi-bin/test.cgi。出现这个问题的原始是我们没有使能mod_alias,也没有在配置文件中将/cgi-bin指向/var/lighttpd/cgi-bin目录。所以lighttpd会去寻找var/lighttpd/htdocs/cgi-bin/test.cgi。如果不想修改配置文件,就需要将test.cgi放置到var/lighttpd/htdocs/cgi-bin/目录中。

测试结果

修改文件路径后,再次测试,程序可以正常运行了。

结语

通过上述排查与实践可见,在嵌入式开发板中调试 Lighttpd 的 CGI 功能时,路径配置的准确性与模块启用状态是关键突破口。从最初因未正确配置mod_alias导致服务器误读脚本路径,到借助strace工具精准定位文件查找逻辑,这一系列过程不仅体现了系统调用跟踪工具在底层调试中的价值,也再次印证了嵌入式环境下配置细节对功能实现的直接影响。

希望本文的解决过程能为嵌入式 Web 服务开发提供参考,帮助开发者在面对类似路径解析或模块冲突问题时,能更系统地分析与解决。如需进一步探讨 Lighttpd 在嵌入式场景中的优化策略或其他调试技巧,欢迎在评论区交流!

相关文章:

  • 对选择基于模型编程(MBD)的工作对职业发展影响的讨论 (2025)
  • 数据库安全性
  • Python训练打卡Day39
  • cursor升级至0.505,运行统计视频中的人数
  • GIS数据类型综合解析
  • NodeJS全栈开发面试题讲解——P3数据库(MySQL / MongoDB / Redis)
  • 6级翻译学习
  • 计算机视觉---YOLOv5
  • Python打卡训练营Day42
  • 深入理解短链服务:原理、设计与实现全解析
  • 鸿蒙OSUniApp结合机器学习打造智能图像分类应用:HarmonyOS实践指南#三方框架 #Uniapp
  • ERP系统中商品定价功能设计:支持渠道、会员与批发场景的灵活定价机制
  • 如何用利用deepseek的API能力来搭建属于自己的智能体-优雅草卓伊凡
  • 【无标题】安富莱V5程序移植到原子探索者F4控制板带TFT LCD显示屏
  • 进程信号简述
  • 6.01打卡
  • DDD架构
  • 【RocketMQ 生产者和消费者】- 生产者发送同步、异步、单向消息源码分析(1)
  • 2025——》NumPy中的np.random.randn使用/在什么场景下适合使用np.random.randn?NumPy标准正态分布生成全解析
  • 平移坐标轴 +奇偶性 简化二重积分
  • 做系统前怎么保存网站上的收藏/大数据营销名词解释
  • 网站模板 安全吗/淘宝关键词优化怎么弄
  • 做网站抄代码/网络营销策略分析案例
  • 宜都网站设计/销售培训课程
  • 中企动力网站/市场调研报告500字
  • 上海家政公司排名/福建百度seo排名点击软件