- UID
- 1029342
- 性别
- 男
|
三、From输入的分析和解码
1.分析名字/值对
当用户提交一个HTML Form时,Web浏览器首先对Form中的数据以
名字/值对的形式进行编码,并发送给Web服务器,然后由Web服务器传 递给CGI程序。其格式如下:
name1=value1&name2=value2&name3=value3&name4=value4&...
其中名字是Form中定义的INPUT、SELECT或TEXTAREA等标置(Tag)
名字,值是用户输入或选择的标置值。这种格式即为URL编码,程序中 需要对其进行分析和解码。要分析这种数据流,CGI程序必须首先将数
据流分解成一组组的名字/值对。这可以通过在输入流中查找下面的 两个字符来完成。
每当找到字符=,标志着一个Form变量名字的结束;每当找到字符& ,标志着一个Form变量值的结束。请注意输入数据的最后一个变量的
值不以&结束。
一旦名字/值对分解后,还必须将输入中的一些特殊字符转换成相 应的ASCII字符。这些特殊字符是:
+:将+转换成空格符;
%xx:用其十六进制ASCII码值表示的特殊字符。根据值xx将其转 换成相应的ASCII字符。
对Form变量名和变量值都要进行这种转换。下面是一个对Form数 据进行分析并将结果回送给Web服务器的CGI程序。
|
#include <stdio.h>
#include <stdlib.h>
#include <strings.h>
int htoi(char *);
main()
{
int i,n;
char c;
printf (″Contenttype: text/plain\n\n″);
n=0;
if (getenv(″CONTENT-LENGTH″))
n=atoi(getenv(″CONTENT-LENGTH″));
for (i=0; i<n;i++){
int is-eq=0;
c=getchar();
switch (c){
case ′&′:
c=′\n′;
break;
case ′+′:
c=′ ′;
break;
case ′%′:{
char s[3];
s[0]=getchar();
s[1]=getchar();
s[2]=0;
c=htoi(s);
i+=2;
}
break;
case ′=′:
c=′:′;
is-eq=1;
break;
};
putchar(c);
if (is-eq) putchar(′ ′);
}
putchar (′\n′);
fflush(stdout);
}
/* convert hex string to int */
int htoi(char *s)
{
char *digits=″0123456789ABCDEF″;
if (islower (s[0])) s[0]=toupper(s[0]);
if (islower (s[1])) s[1]=toupper(s[1]);
return 16 * (strchr(digits, s[0]) -strchr (digits,′0′)
)
+(strchr(digits,s[1])-strchr(digits,′0′));
}
|
上面的程序首先输出一个MIME头信息给Web服务器,检查输入中的
字符数,并循环检查每一个字符。当发现字符为&时,意味着一个名字/ 值对的结束,程序输出一个空行;当发现字符为+时,将它转换成空格;
当发现字符为%时,意味着一个两字符的十六进制值的开始,调用hto i ()函数将随后的两个字符转换为相应的ASCII字符;当发现字符为=时,
意味着一个名字/值对的名字部分的结束,并将它转换成字符:。最后 将转换后的字符输出给Web服务器。 |
|