C语言url编解码

Python020

C语言url编解码,第1张

url编码的详细解释可以参考: https://blog.csdn.net/xiaojianpitt/article/details/1946744

注意这里:空格字符 " " 转换为一个加号 "+",有些是这样转换的,但是有些浏览器" "转换为%20

socket无法解析url

解析url的包括两种服务,一种是DNS,一种是url服务器提供的服务。

DNS负责将url中的域名解析为ip和端口,进而用户的计算机可以将url投递到目标服务器上。

然后服务器依据url中的请求,做出相应,并应答用户。

这些数据通信都是发生在tcp/ip层上的。而socket工作在此层,即socket为url访问提供服务,而非直接处理url

txt读入温度,湿度等数据。

用printf()输出 HTML 文件。

#define LF 10

#define CR 13

int wendu,shidu

char shijian[20]

FILE *fin

// 打开data.txt,读入 wendu,shidu,shijian,关文件

// 下来输出

printf("<HTML>%c",LF)

printf("<HEAD><TITLE>web界面</TITLE></HEAD>%c",LF)

printf("<meta http-equiv=\"Content-Type\"

content=\"text/html\"charset=\"gb2312\" />)

printf("<BODY>%c",LF)

printf("<H2>温度:%d 湿度:%d 时间:%s</H2>%c",LF,wendu,shidu,shijian)

printf("<HR></BODY></HTML>%c",LF)

===============================================

网上留言获取,变量名字与网页定义有关。

char *cl

char manydata[10240]

void getword(char *word, char *line, char stop) {

int x = 0,y

for(x=0((line[x]) &&(line[x] != stop))x++)

word[x] = line[x]

word[x] = '\0'

if(line[x]) ++x

y=0

while(line[y++] = line[x++])

}

void unescape_url(char *url) {

register int x,y

for(x=0,y=0url[y]++x,++y) {

if((url[x] = url[y]) == '%') {

url[x] = x2c(&url[y+1])

y+=2

}

}

url[x] = '\0'

}

void plustospace(char *str) {

register int x

for(x=0str[x]x++) if(str[x] == '+') str[x] = ' '

}

返回信息长度:

char_l = atoi(getenv("CONTENT_LENGTH"))

cl = &manydata[0]

分离变量名与值(即内容):

for (i=0i <char_l i++) {

*( cl + i) = (char)fgetc(stdin)

}

*( cl + char_l) = '\0'

查找需要的变量名与值:

for(x=0cl[0] != '\0'x++) {

m=x

getword(w,cl,'=')

plustospace(w)

unescape_url(w)

if( strcmp(w,"name") == 0) {

getword(w,cl,'&')

plustospace(w)

unescape_url(w)

strcpy(name,w)

}

。。。。

}

---------------------------------

另外,团IDC网上有许多产品团购,便宜有口碑