使用lighttpd和开发板进行交互

文章目录

    • [🧠 一、Lighttpd 与开发板的交互原理](#🧠 一、Lighttpd 与开发板的交互原理)
      • [1. 什么是 Lighttpd?](#1. 什么是 Lighttpd?)
      • [2. 与开发板交互的方式?](#2. 与开发板交互的方式?)
    • [🧾 二、lighttpd.conf 配置文件讲解](#🧾 二、lighttpd.conf 配置文件讲解)
      • [⚠️ 注意事项:](#⚠️ 注意事项:)
    • [📁 三、目录结构说明](#📁 三、目录结构说明)
    • [💡 四、使用 C 编写 CGI 脚本(实现点灯)](#💡 四、使用 C 编写 CGI 脚本(实现点灯))
      • [1. 示例:C语言 CGI 脚本(控制 GPIO)](#1. 示例:C语言 CGI 脚本(控制 GPIO))
      • [2. 编译并设置权限](#2. 编译并设置权限)
    • [🌐 五、网页中调用 CGI(按钮触发)](#🌐 五、网页中调用 CGI(按钮触发))
    • [🛠️ 六、调试建议](#🛠️ 六、调试建议)
    • [✅ 总结](#✅ 总结)

🧠 一、Lighttpd 与开发板的交互原理

1. 什么是 Lighttpd?

Lighttpd 是一个轻量级 Web 服务器,适合资源受限的嵌入式开发板运行。它支持:

  • 静态网页服务(HTML、图片等)
  • 动态网页处理(如 CGI 脚本)
  • 支持 FastCGI、SCGI、URL 重写等

2. 与开发板交互的方式?

Lighttpd 自身不直接控制硬件(比如点灯),而是通过调用 CGI 程序(通常是用 C 语言或 shell 写的),这些程序再调用开发板底层的接口,比如:

  • 操作 GPIO 口实现"点灯"
  • 读取传感器数据返回网页
  • 执行控制指令等

总结:网页点击按钮 → 请求 CGI 脚本 → 脚本操作硬件并返回结果 → 网页展示结果


🧾 二、lighttpd.conf 配置文件讲解

一个典型的配置如下:

conf 复制代码
server.modules = (
    "mod_access",
    "mod_alias",
    "mod_compress",
    "mod_redirect",
    "mod_rewrite",
    "mod_cgi"
)

server.document-root = "/etc/lighttpd/www"   # 网站根目录
server.port = 8080                           # 启动监听端口
server.errorlog = "/etc/lighttpd/error.log"  # 错误日志
dir-listing.activate = "enable"              # 浏览目录功能

index-file.names = ( "index.html" )          # 默认主页文件名

mimetype.assign = (
    ".html" => "text/html",
    ".txt"  => "text/plain",
    ".jpg"  => "image/jpeg",
    ".png"  => "image/png",
    ""      => "application/octet-stream"
)

# 配置 CGI 路由规则
$HTTP["url"] =~ "^/cgi-bin/" {
    cgi.assign = ( ".cgi" => "" )
}

⚠️ 注意事项:

  • accesslog.filenameserver.modules-dir 是无效选项,可以删除;
  • cgi.assign 中的 "cgi" 要确保对应文件有执行权限;
  • mod_cgi 必须包含在 server.modules 中。

📁 三、目录结构说明

比如 /etc/lighttpd/ 目录结构如下:

复制代码
/etc/lighttpd/
├── www/                   # 网站根目录
│   ├── index.html         # 默认主页
│   └── cgi-bin/           # CGI 程序存放目录
│       └── led.cgi        # 用 C 写的 CGI 程序
├── lighttpd.conf          # 配置文件
├── error.log              # 错误日志
└── access.log             # 访问日志(可选)

💡 四、使用 C 编写 CGI 脚本(实现点灯)

1. 示例:C语言 CGI 脚本(控制 GPIO)

代码:led.cgi

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int main(void) {
    printf("Content-type: text/html\n\n");
    printf("<html><body>");

    // 简单模拟点灯,真实环境用 /sys/class/gpio/ 或驱动接口
    system("echo 1 > /sys/class/leds/led0/brightness");

    printf("<h1>LED 已开启!</h1>");
    printf("</body></html>");

    return 0;
}

2. 编译并设置权限

sh 复制代码
# 交叉编译
aarch64-linux-gcc -o led.cgi led.c

# 放入 CGI 目录
cp led.cgi /etc/lighttpd/www/cgi-bin/
chmod +x /etc/lighttpd/www/cgi-bin/led.cgi

🌐 五、网页中调用 CGI(按钮触发)

index.html 示例:

html 复制代码
<!DOCTYPE html>
<html>
<head><title>LED 控制</title></head>
<body>
    <h1>控制面板</h1>
    <form action="/cgi-bin/led.cgi" method="GET">
        <button type="submit">点亮LED</button>
    </form>
</body>
</html>

访问开发板网页:http://开发板IP:8080

点击按钮,即会请求 /cgi-bin/led.cgi,从而点亮灯。


🛠️ 六、调试建议

  • 404 错误排查

    • 确认 URL 是 /cgi-bin/*.cgi
    • CGI 文件可执行 (chmod +x)
    • 文件路径正确,配置中的路径匹配上
  • 权限问题

    • CGI 操作硬件需 root 权限运行
    • 确保 CGI 能访问 /sys/class/gpio 或相关硬件路径
  • 日志查看

    sh 复制代码
    cat /etc/lighttpd/error.log

✅ 总结

项目 内容
Web 服务 Lighttpd 监听 8080 端口,提供页面
动态响应 使用 C 编写的 CGI 程序,响应用户点击
硬件控制 CGI 调用系统命令或控制设备驱动实现
网页交互 表单或 JS 请求触发 CGI 执行
关键配置 mod_cgicgi-bin、执行权限

效果实现:

点击后可以跳转到另外一个界面:

相关推荐
爱出名的狗腿子18 小时前
vscode + cmake + ninja+ gcc 搭建MCU开发环境
ide·vscode·单片机·c·cmake·gcc·ninja
闻道且行之5 天前
驱动开发(2)|鲁班猫rk3568简单GPIO波形操控
驱动开发·rk3568
比特森林探险记6 天前
FreeRTOS在车窗控制中的核心价值
c++·c
略无慕艳意11 天前
【教程】Ubuntu 16.04 配置 CLion 开发 ROS Melodic
c++·ros·c·clion
mucheni12 天前
itop-3568开发板驱动开发指南-实验程序的编写
rk3568
梁辰兴15 天前
数据结构实验10.1:内部排序的基本运算
数据结构·c++·算法·排序算法·c·内部排序
莱茵不哈哈20 天前
初探 Skynet:轻量级分布式游戏服务器框架实战
lua·c·skynet
花落已飘20 天前
LVGL(lv_btnmatrix矩阵按钮)
ui·c·lvgl
编程百晓君20 天前
C语言速成之07switch语句详解:多分支选择的高效实现
c