cgic 为C语言编写CGI的C函数库
更新时间:2024-04-19 03:12:01 阅读量: 综合文库 文档下载
- cgicken推荐度:
- 相关推荐
cgic: 为C语言编写CGI的C函数库 由Thomas Boutell开发 目录
CGIC介绍
怎样写CGIC应用程序 怎样产生图片在CGIC中? CGI调试特征: 利用捕获 cgic函数参考 cgic变量参考
cgic结果编码参考 cgic快速索引
一般的UNIX系统都支持ANSIC,增加相应的库函数(和相应的h文件)就可以实现CGI。在此我向大家推荐一个用于CGI编程的ANSIC库:cgic。
cgic是用来生成基于CGI的WWW应用程序的C语言函数库,它有以下功能:
*对数据进行语法分析
*接收以GET和PSOT两种方式发送的数据
*把FORM中的不同域连接成连续的串
*为检索FORM数据而提供字符串,整数,浮点以及单项和多项选择功能
*为数字字段提供边界检测
*把CGI环境变量加载到非空的C串中
*为调试而捕捉CGI状态
*提供相对安全的系统调用功能
用一般ANSI C或C++编译器就可以编译cgic程序,不过与通常C程序不同的是,用cgic写的源码其主函数是cgiMain(),而不是通常的main()。cgic的函数库会自动把cgiMain连接到相应的main()上去。
--------------------------------------------------------------------------------
写CGIC程序
Note: 所有的cgic应用程序必须连接cgic.c.
用cgimain()替代main() 必须包含: #include\
基本结构cgictest.c:
int cgiMain() { #if DEBUG
/* Load a saved CGI scenario if we're debugging */ cgiReadEnvironment(\ #endif
/* Important: we must indicate the type of document */ cgiHeaderContentType(\
/* Now invoke other functions to handle each part of the form */ fprintf(cgiOut, \
fprintf(cgiOut, \ fprintf(cgiOut, \ Name(); Address(); Hungry();
Temperature(); Frogs(); Color(); Flavors();
NonExButtons(); RadioButtons();
fprintf(cgiOut, \
/* This value will be the exit code of the program; 0
generally indicates success among Unix and DOS programs */ return 0; }
capture 输出标头
cgiHeaderContentType()在输出文挡之前简要说明MIME内型,如 \。 cgiHeaderStatus()代替输出错误代码 cgiHeaderLocation()代替重新引导至其他页面。在一个独立的应用程序中只能有一个cgiHeader函数。
重点:在cgiHeader函数组中, cgiHeaderContentType(), 在任何向浏览器输出之前被调用. 否则将出错或浏览器不能识别。 cgiOut
接着, cgiMain() 调用不同的函数.当函数结束后,将返回0
处理输入文本
void Name() { char name[81];
cgiFormStringNoNewlines(\ fprintf(cgiOut, \ }
这个函数的功能就是取的并显示由用户输入的name . 处理输出
Important: cgiOut通常相当于stdout
cgiFormString 确保断航
处理单一Checkboxes输入
这个Hungry() function确定用户是否选择\这个 checkbox: void Hungry() {
if (cgiFormCheckboxSingle(\ fprintf(cgiOut, \ } else {
fprintf(cgiOut, \ } }
这个函数依靠 cgiFormCheckboxSingle() 确定单一的checkbox 被选择。 cgiFormCheckboxSingle() 接受checkbox名字的属性值,如果存在就返回 cgiFormSuccess,否则返回cgiFormNotFound 如果是多项checkboxes,就用 cgiFormCheckboxMultiple()和cgiFormStringMultiple() 函数. 处理数字输入
Temperature() 返回浮点书的值确保在特定的返回内。 void Temperature() { double temperature;
cgiFormDoubleBounded(\ fprintf(cgiOut, \ }
依靠cgiFormDoubleBounded()得到数据.第一个数据是返回数据中输入域的名字。最后一个值是用户没有提交时的默认值。
这个函数总是找回在特定返回内合适的值; cgiFormDoubleBounded返回的值被检查确信用户输入的资料在规定范围内, 而不是其他无效的数据。查看 cgiFormDoubleBounded() 更多的资料. 如果限度检查不理想,可以用 cgiFormDouble() 替代.
在整数输入,cgiFormInteger 和 cgiFormIntegerBounded 可以利用. 这些函数的功能类似.
处理单一选择输入
void Color() { int colorChoice;
cgiFormSelectSingle(\ fprintf(cgiOut, \ }
这个函数确定用户选择了几个选项从
cgiFormSelectSingle() 总是显示合理的选项值.
radio button也可以用这个函数.另外还有 cgiFormRadio(), 也是一样的
处理多项选择的输入 NonExButtons() char *votes[] = { \ \ \ \ };
void NonExButtons() { int voteChoices[4]; int i; int result; int invalid;
char **responses;
/* Method #1: check for valid votes. This is a good idea, since votes for nonexistent candidates should probably be discounted... */
fprintf(cgiOut, \otes (method 1):
\\n\
result = cgiFormCheckboxMultiple(\
voteChoices, &invalid);
if (result == cgiFormNotFound) {
fprintf(cgiOut, \ } else {
fprintf(cgiOut, \ fprintf(cgiOut, \ for (i=0; (i < 4); i++) { if (voteChoices[i]) {
fprintf(cgiOut, \ } }
fprintf(cgiOut, \ }
参考cgiFormCheckboxMultiple(), cgiFormSelectMultiple(). cgiFormCheckboxMultiple() cgiFormCheckboxMultiple
NonExButtons() 函数在 cgictest.c:
/* Method #2: get all the names voted for and trust them. This is good if the form will change more often
than the code and invented responses are not a danger or can be checked in some other way. */ fprintf(cgiOut, \otes (method 2):
\\n\
result = cgiFormStringMultiple(\ if (result == cgiFormNotFound) {
fprintf(cgiOut, \ } else { int i = 0;
fprintf(cgiOut, \ fprintf(cgiOut, \ while (responses[i]) {
fprintf(cgiOut, \ i++; }
fprintf(cgiOut, \ }
/* We must be sure to free the string array or a memory leak will occur. Simply calling free() would free the array but not the individual strings. The
function cgiStringArrayFree() does the job completely. */ cgiStringArrayFree(responses); }
参考cgiFormStringMultiple() cgiFormStringMultiple()
/* An array of strings; each C string is an array of characters */ char **responses;
cgiFormStringMultiple(\
检查CGI环境变量 将用到的变量 这里, 产生图象
#include \ #include \
char *colors[] = { \ };
#define colorsTotal 3
int cgiMain() { int colorChosen; gdImagePtr im; int r, g, b;
/* Use gdto create an image */ im = gdImageCreate(64, 64);
r = gdImageColorAllocate(im, 255, 0, 0); g = gdImageColorAllocate(im, 0, 255, 0); b = gdImageColorAllocate(im, 0, 0, 255);
/* Now use cgic to find out what color the user requested */ cgiFormSelectSingle(\/* Now fill with the desired color */ switch(colorChosen) { case 0:
gdImageFill(im, 32, 32, r); break; case 1:
gdImageFill(im, 32, 32, g); break; case 2:
gdImageFill(im, 32, 32, b); break; }
/* Now output the image. Note the content type! */ cgiHeaderContentType(\/* Send the image to cgiOut */ gdImageGif(im, cgiOut); /* Free the gd image */ gdImageDestroy(im); return 0; }
为调试而捕捉CGI状态 cgic函数参考
cgiFormResultType cgiFormString( char *name, char *result, int max) 用于从输入域中copy字符串。他将域名max-1字节中的字符copy到缓冲区result。若域不存在,则copy一个空串到result缓冲区。在此函数中所有的新行由换行符代表。
cgiFormResultType cgiFormStringNoNewlines( char *name, char *result, int max)
它与cgiFormString函数相似,只是所有的CR和LF都被去掉了。
cgiFormResultType cgiFormStringSpaceNeeded( char *name, int *length) 它返回指向name的字符串的长度,并将长度放入length中。
cgiFormResultType cgiFormStringMultiple( char *name, char ***ptrToStringArray)
若同一名字有多个输入域,或域中的字符串可以动态变化,那么你可以使用本函数。它把名为name的所有输入域的值放在prtToStringArray中。
void cgiStringArrayFree(char **stringArray) 它释放了分配给stringArray的内存。
cgiFormResultType cgiFormInteger( char *name, int *result, int defaultV) 从输入域中取出整数放入result中。
cgiFormResultType cgiFormIntegerBounded( char *name, int *result, int min, int max, int defaultV)
若输入域中的整数在界限内则取出并放入result中。
cgiFormResultType cgiFormDouble( char *name, double *result, double defaultV)
从输入域中取出浮点数放入result中。
cgiFormResultType cgiFormDoubleBounded( char *name, double *result, double min, double max, double defaultV)
若输入域中的浮点数在界限内则取出并放入result中。
cgiFormResultType cgiFormSelectSingle( char *name, char **choicesText, int choicesTotal, int *result, int defaultV)
取出复选框(跟在select语句之后的),把选择的名字copy到choicesText,把选择的个数copy到choicesTotal,把当前的选择copy到result。
cgiFormResultType cgiFormSelectMultiple( char *name, char **choicesText, int choicesTotal, int *result, int *invalid)
与cgiFormSelectSingle类似,只指向整型数组的result代表了选择的项。
cgiFormResultType cgiFormCheckboxSingle( char *name)
若复选框被选中,则函数返回cgiFormSuccess,否则返回cgiFormNotFound。
cgiFormResultType cgiFormCheckboxMultiple( char *name, char **valuesText, int valuesTotal, int *result, int *invalid)
与cgiFormCheckboxSingle类似,但它处理同一名字有多个复选框的情况。name指向复选框的名字;valuesText指向包含有每个复选框中参数的一个数组;valuesTotal指向复选框的总数;result是一个整型数组,每个复选框选中的用1代表,没选中的用0代表。
cgiFormResultType cgiFormRadio( char *name, char **valuesText, int valuesTotal, int *result, int defaultV)
与cgiFormCheckboxMultiple相似,只是这里是单选按钮而不是复选框。
void cgiHeaderLocation(char *redirectUrl) 重定向到redirectUrl指定的URL。
void cgiHeaderStatus(int status, char *statusMessage) 输出状态代码status和消息statusMessage。
void cgiHeaderContentType(char *mimeType) 用于告知浏览器返回的是什么类型的文档。
cgiEnvironmentResultType cgiWriteEnvironment(char *filename) 本函数把当前CGI环境写入filename文件中以便以后调试时使用
cgiEnvironmentResultType cgiReadEnvironment(char *filename) 本函数从filename文件中读取CGI环境以便用来调试。
int cgiMain()
一个程序必须要写这个函数, 这是主程序开始之处。 cgic变量参考
This section provides a reference guide to the various global variables provided by cgic for the programmer to utilize. These variables should always be
used in preference to stdin, stdout, and calls to getenv() in order to ensure compatibility with the cgic CGI debugging features.
大多数的变量相当于各种CGI变量,重要的是VGIC的变量不能为空.
char *cgiServerSoftware
服务器软件名称,或者一个空的字符串 or to an empty string if unknown. char *cgiServerName 返回服务器名称或空 char *cgiGatewayInterface
网关接口 (通常是 CGI/1.1),或空 char *cgiServerProtocol
网络协议(usually HTTP/1.0),或空 char *cgiServerPort
服务器端口(usually 80),或空 char *cgiRequestMethod
请求方式 (usually GET or POST),或空 char *cgiPathInfo 指出附加虚拟路径 char *cgiPathTranslated
指出附加虚拟路径并由服务器转为本地路径 char *cgiScriptName 调用程序的名字 char *cgiQueryString
包含 GET-method 请求或者
从浏览器返回客户主机的名字 char *cgiRemoteAddr
从浏览器返回客户的IP地址 char *cgiAuthType 返回用户授权信息 char *cgiRemoteUser 鉴别用户 cgiAuthType. char *cgiRemoteIdent 返回用户的名字(用户通过用户坚定协议)这个消息是不安全的,特别是Windows系统。
char *cgiContentType 返回MIME内型 char *cgiAccept
参考 cgiHeaderContentType() cgiUserAgent char *cgiUserAgent 取的用户浏览器信息 char *cgiReferrer
指向用户访问的URL.
int cgiContentLength
表单或查询数据的字节被认为是标准的. FILE *cgiOut
CGI输出. cgiHeader函数,象cgiHeaderContentType, 首先被用于输出mime头; 用于 fprintf() 和fwrite(). cgiOut通常相当于stdout。 FILE *cgiIn
CGI输入. 在决大部分时间你都不会需要这个函数。 cgic结果编码参考
在大量的按列中, cgic函数有计划的产生合理的结果,甚至浏览器和用户不合理时。无论如何, 有时候知道不合理的事情发生,尤其赋予一个值或定义一个范围是一个不充分的解决方案。下面的这些结果编码有助更好了解。
cgiFormSuccess 提交信息成功 cgiFormTruncated 删除部分字节. cgiFormBadType
错误的输入信息(没有按要求) cgiFormEmpty 提交信息为空. cgiFormNotFound 提交信息没有找到. cgiFormConstrained
数字属于某个特定的范围,被迫低于或高于适当范围。 cgiFormNoSuchChoice
单一选择提交的值是不被接受。通常说明表但和程序之间存在矛盾。 cgiEnvironmentIO
从CGI环境或获取的文件读或写的企图失败,报出I/O的错误。 cgiEnvironmentMemory
从CGI环境或获取的文件读或写的企图失败,报出out-of-memory的错误。 cgiEnvironmentSuccess
从CGI环境或获取的文件读或写的企图成功。 cgic快速索引
cgiAccept | cgiAuthType | cgiContentLength | cgiContentType | cgiEnvironmentIO | cgiEnvironmentMemory | cgiEnvironmentSuccess | cgiFormBadType | cgiFormCheckboxMultiple() | cgiFormCheckboxSingle() | cgiFormConstrained | cgiFormDouble() | cgiFormDoubleBounded() | cgiFormEmpty | cgiFormInteger() | cgiFormIntegerBounded() | cgiFormNoSuchChoice | cgiFormNotFound | cgiFormRadio() | cgiFormSelectMultiple() | cgiFormSelectSingle() | cgiFormString() | cgiFormStringMultiple() | cgiFormStringNoNewlines() | cgiFormStringSpaceNeeded() | cgiFormSuccess | cgiFormTruncated | cgiGatewayInterface | cgiHeaderContentType() | cgiHeaderLocation() | cgiHeaderStatus() | cgiIn | cgiMain() cgiOut | cgiPathInfo | cgiPathTranslated | cgiQueryString | cgiReadEnvironment() | cgiReferrer() | cgiRemoteAddr | cgiRemoteHost | cgiRemoteIdent | cgiRemoteUser |
cgiRequestMethod | cgiScriptName | cgiServerName | cgiServerPort | cgiServerProtocol | cgiServerSoftware | cgiStringArrayFree() | cgiUserAgent | cgiWriteEnvironment()
正在阅读:
cgic 为C语言编写CGI的C函数库04-19
警察个人思想汇报02-24
2017届高考政治时政热点推动“双创”工作激发创业活力资料03-08
抓蟑螂作文500字07-13
江苏清能2019年财务状况报告04-29
啤酒工艺学毕业设计第一部分07-18
拔摩先知的经历11-22
桥梁技术状况评定标准继续教育答案04-21
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 函数
- 编写
- 语言
- cgic
- CGI
- 中国房地产开发商排名百强榜单
- 2017-2022年中国白铜行业监测及投资机遇研究报告 - 图文
- AutoLISP例程:读取excel文件
- ARM中断基础知识 - 图文
- 五险一金的使用方法
- 广州市白云区安全生产监督管理局局长办公会议制度(暂行)
- 软件工程专业毕业设计指导规范(面向对象)
- 中国景观设计师的出路在哪里 - 图文
- 人力资源部2017年度工作总结及2018年工作计划(Word版
- 依托美育构建君子教育特色学校结题报告材料汇编 - 图文
- 施工组织设计
- 劳动人事争议仲裁委员会送达制度
- 2017秋五年级英语工作总结
- 国家检验检测机构资质认定管理办法(第163号)
- 高考数学常见题型汇总(精华资料)
- HIV记录本 - 图文
- 《 电路分析基础(A)》课程考试试卷(B)
- 自动售饭机的设计毕业设计论文
- 如何在高中生物课堂进行情感教育
- 人教版高中英语全部单词(必修1至选修8带目录)