写在最前面
华清远见教育集团
15年专注高端IT培训
做良心教育,做专业教育,做受人尊敬的职业教育创客学院官网:http://www.makeru.com.cn/
华清远见创客学院嵌入式课程链接:http://www.makeru.com.cn/emb
华清远见创客学院物联网课程链接:http://www.makeru.com.cn/iot
概述
CGI 是Web 服务器运行时外部程序的规范,按CGI 编写的程序可以扩展服务器功能。CGI 应用程序能与浏览器进行交互,还可通过数据库API 与数据库服务器等外部数据源进行通信,从数据库服务器中获取数据。格式化为HTML文档后,发送给浏览器,也可以将从浏览器获得的数据放到数据库中。几乎所有服务器都支持CGI,可用任何语言编写CGI,包括流行的C、C ++、VB 和Delphi 等。CGI 分为标准CGI 和间接CGI两种。标准CGI 使用命令行参数或环境变量表示服务器的详细请求,服务器与浏览器通信采用标准输入输出方式。间接CGI 又称缓冲CGI,在CGI 程序和CGI 接口之间插入一个缓冲程序,缓冲程序与CGI 接口间用标准输入输出进行通信。
目的:本文从学习的角度来认识CGI。重点是对整体框架的理解,和对CGIC在嵌入式环境的移植。
框图
CGI程序的工作一般就是接收表单数据,进行数据处理,最后根据处理结果生成新的页面返回给浏览器。
CGIC
CGIC是一个功能比较强大的支持CGI开发的标准C库,并支持Linux, Unix 和Windows等多操作系统
源码分析
cgic源码里面有大约10个文件
cgic.h:头文件;
cgic.c:CGIC的源代码文件;
cgictest.c:CGIC库的作者提供的一个CGI程序例子;
capture.c:用于调试CGI程序的工具;
Makefile:安装CGIC的脚本文件;
用户操作流程分析
用户通过客户端应用(浏览器)向web服务发送一个get请求,web服务器返回一个默认的静态html页面;用户想在这个基础上进一步操作,比如用户登录,需要填写 '用户名-密码' 吧,这样提交的信息就以form表单的形式从web服务器,再通过CGI接口向服务器上的应用发送。CGI就是这么一个中间机制,这里简单理解就是讲前端产生的html语言转换成应用层的c语言,实现交互。
CGIC的移植过程
源码移植
1.下载源码
http://www.boutell.com/cgic/
2.解压
root@linux:cgi_test# tar -xvf cgic205.tar.gz
3.修改交叉编译环境
root@linux:cgic205# cd ./cgic205
root@linux:cgic205# vim Makefile
CC=arm-none-linux-gnueabi-gcc
AR=arm-none-linux-gnueabi-ar
RANLIB=arm-none-linux-gnueabi-ranlib
#gcc cgictest.o -o cgictest.cgi ${LIBS}
$(CC) $(CFLAGS) cgictest.o -o cgictest.cgi ${LIBS}
#gcc capture.o -o capture ${LIBS}
$(CC) $(CFLAGS) capture.o -o capture ${LIBS}
4.编译cgi源码
root@linux:cgic205# make
5.将capture和cgictest.cgi拷贝到nfs共享根目录下的boa/cgi-bin/目录中
root@linux:cgic205# ls
capture cgic.c cgic.o cgictest.o Makefile
capture.c cgic.h cgictest.c libcgic.a readme.txt
capture.o cgic.html cgictest.cgi license.txt support.txt
root@linux:cgic205# cp capture cgictest.cgi /nfs/rootfs/boa/cgi-bin/
root@linux:cgic205#
6.测试效果
<1>开发板上
[root@farsight boa]# pwd
/boa
[root@farsight boa]# ./boa
<2>浏览器输入url http://192.168.9.9/cgi-bin/cgictest.cgi
进一步项目移植
1.添加新的文件到cgi源码目录
root@linux:cgi# cp -rf cgi_src-05-30-17-00 ~/cgi_test/cgic205/
root@linux:cgi# cd /root/cgi_test/cgic205/cgi_src-05-30-17-00
root@linux:cgi_src-05-30-17-00# pwd
/root/cgi_test/cgic205/cgi_src-05-30-17-00
root@linux:cgi_src-05-30-17-00# cp m0_* ../
root@linux:cgi_src-05-30-17-00# cp sem.h env1.c login.c setEnv.c data_global.h ../
2.修改Makefile编译规则,把刚才那些文件添加到Makefile编译项
root@linux:cgi_src-05-30-17-00# cd ..
root@linux:cgic205# vim Makefile
CC=arm-none-linux-gnueabi-gcc
AFLAGS=-Wall -g
LDFLAGS= -L ./lib
OBJS= capture.cgi m0_beep.cgi m0_fan.cgi m0_led.cgi \
m0_seg.cgi env1.cgi setEnv.cgi
run:$(OBJS)
$(OBJS):%.cgi:%.c
$(CC) $(AFLAGS) $< cgic.c -o $@ $(LDFLAGS)
install:
$(CC) $(AFLAGS) login.c -o login.cgi
mv *.cgi ./out/
cp ./out/*.cgi /nfs/rootfs/boa/cgi-bin
.PHONY:clean
clean:
rm ./out/*.cgi
3.编译并将目标文件移动到nfs根目录下
root@linux:cgic205# make
root@linux:cgic205# make install
4.在/nfs/rootfs/boa/www下添加需要的html文件
root@linux:boa# ls www/
choose.html env2.html index.html m0_2.html main2.html video1.html
env1.html images m0_1.html main1.html pice video2.html
root@linux:boa# cp -rf www/* /nfs/rootfs/boa/www/
5.查看效果
用户通过浏览器访问开发板IP,web服务器返回一个默认页面
用户通过输入栏,填写用户名密码(提交表单),web服务器通过cgi接口返回又一个页面
扩展学习-cgic官网学习教程:https://boutell.com/cgic/