\n"); cgiHtmlEscape(username); fprintf(cgiOut, "\n"); char password[241]; cgiFormString("password", password, 241); fprintf(cgiOut, "password:
\n"); cgiHtmlEscape(password); fprintf(cgiOut, "\n"); char sql[300]={'\0'}; //ä¸èƒ½ç”¨æŒ‡é’? //æ’å…¥æ•°æ® sprintf(sql, "INSERT INTO \"user\" VALUES('%s', '%s');", username,password); //sql = "INSERT INTO \"user\" VALUES('username', 'password');" ; sqlite3_exec( db , sql , 0 , 0 , &zErrMsg ); printf(sql); printf("æ’å…¥æ•°æ®æˆåŠŸ!\n"); int nrow = 0, ncolumn = 0; char **azResult; //äºŒç»´æ•°ç»„å˜æ”¾¾l“æžœ //æŸ¥è¯¢æ•°æ® /* int sqlite3_get_table(sqlite3*, const char *sql,char***result , int *nrow , int *ncolumn ,char **errmsg ); result䏿˜¯ä»¥æ•°¾l„的形å¼å˜æ”¾ä½ 所查询的数æ®ï¼Œé¦–先是表åï¼Œå†æ˜¯æ•°æ®ã€? nrow ,ncolumn分别为查询è¯å¥è¿”回的¾l“果集的行数åQŒåˆ—敎ͼŒæ²¡æœ‰æŸ¥åˆ°¾l“果时返å›? */ char *sql2 = "SELECT * FROM user"; sqlite3_get_table( db , sql2 , &azResult , &nrow , &ncolumn , &zErrMsg ); int i = 0 ; printf( "row:%d column=%d
#include<stdio.h>
#include<stdlib.h>
#define MAXLEN 80
#define EXTRA 5
/* 4个å—节留¾l™å—ŒD늚„åå—"data", 1个å—节留¾l?=" */
#define MAXINPUT MAXLEN+EXTRA+2
/* 1个å—节留¾l™æ¢è¡Œç¬¦åQŒè¿˜æœ‰ä¸€ä¸ªç•™¾l™åŽé¢çš„NULL */
#define DATAFILE "../data/data.txt"
/* è¦è¢«æ·ÕdŠ æ•°æ®çš„æ–‡ä»?nbsp; */
void unencode(char *src, char *last, char *dest)
{
for(; src != last; src++, dest++)
if(*src == "+")
*dest = " ";
else if(*src == "%") {
int code;
if(sscanf(src+1,"%2x",&code)!=1)code="?";
*dest=code;
src +=2;}
else
*dest=*src;
*dest=" ";
*++dest="";
}
int main(void)
{
char *lenstr;
char input[MAXINPUT], data[MAXINPUT];
long len;
printf("%s%c%c", "Content-Type:text/html;charset=gb2312",13,10);
printf("<TITLE>Response</TITLE>");
lenstr=getenv("CONTENT_LENGTH");
if(lenstr==NULL || sscanf(lenstr,"%ld",&len)!=1 || len>MAXLEN)
printf("<P>è¡¨å•æäº¤é”™è¯¯");
else{
FILE *f;
fgets(input, len+1, stdin);
unencode(input+EXTRA, input+len, data);
f =fopen(DATAFILE, "a");
if(f == NULL)
printf("<P>对ä¸èµøP¼Œæ„外错误åQŒä¸èƒ½å¤Ÿä¿å˜ä½ 的数æ®");
else
fputs(data, f);
fclose(f);
printf("<P>éžå¸¸æ„Ÿè°¢åQŒæ‚¨çš„æ•°æ®å·²¾l被ä¿å˜<BR>%s",data);
}
return 0;
}
   从本质上æ¥çœ‹åQŒç¨‹åºå…ˆä»ŽCONTENT_LENGTH环境å˜é‡ä¸å¾—到数æ®çš„å—é•¿åQŒç„¶åŽè¯»å–相应长度的å—符丌Ӏ‚å› ä¸ºæ•°æ®å†…å®¹åœ¨ä¼ è¾“çš„è¿‡½E‹ä¸æ˜¯ç»˜q‡äº†¾~–ç 的,所以必™å»è¿›è¡Œç›¸åº”的解ç 。编ç 的规则很简å•,主è¦çš„æœ‰˜q™å‡ æ?
1. 表å•䏿¯ä¸ªæ¯ä¸ªå—ŒD는¨å—段ååŽè·Ÿç‰åøP¼Œå†æŽ¥ä¸Šä¸Š˜q™ä¸ªå—段的值æ¥è¡¨ç¤ºåQŒæ¯ä¸ªå—ŒDµä¹‹é—´çš„内容ç”?amp;˜qžç»“åQ?nbsp; 2. 所有的½Iºæ ¼½W¦å·ç”¨åŠ å·ä»£æ›¿ï¼Œæ‰€ä»¥åœ¨¾~–ç ç æ®µä¸å‡ºçŽ°ç©ºæ ¼æ˜¯éžæ³•的;
3. ç‰ÒŽ®Šçš„å—½W¦æ¯”å¦‚æ ‡ç‚¹ç¬¦åøP¼Œå’Œä¸€äº›æœ‰ç‰¹å®šæ„义的嗽W¦å¦‚“+”åQŒç”¨ç™‘Öˆ†å·åŽè·Ÿå…¶å¯¹åº”çš„ACSIIç 值æ¥è¡¨ç¤ºã€?nbsp;
例如åQšå¦‚æž?a class="qs_highlight1" id="hl_5" onmouseover="window.clearTimeout(_ht[5]);qs_show_frame(event,this,5);" style="font-size: 1em" onclick="_write_cookie('click46',5);" onmouseout="_on_div[5]=false;_ht[5]=window.setTimeout('qs_is_on_div(5)',500);" target="_blank">用户输入的是åQ?nbsp;
Hello there!
那么数æ®ä¼ é€åˆ°æœåŠ¡å™¨çš„æ—¶å€™ç»˜q‡ç¼–ç ,ž®±å˜æˆäº†data=Hello+there%21 上é¢çš„unencodeåQˆï¼‰å‡½æ•°ž®±æ˜¯ç”¨æ¥æŠŠç¼–ç åŽçš„æ•°æ®è¿›è¡Œè§£ç 的。在解ç 完æˆåŽï¼Œæ•°æ®è¢«æ·»åŠ åˆ°data.txtæ–‡äšg的尾部,òq¶åœ¨‹¹è§ˆå…¶ä¸å›žæ˜¾å‡ºæ¥ã€?nbsp;
把文件编译完æˆåŽåQŒæŠŠå®ƒæ”¹å䨓collect.cgiåŽæ”¾åœ¨CGI目录ä¸å°±å¯ä»¥è¢«è¡¨å•调用了。下é¢ç»™å‡ÞZº†å…¶ç›¸åº”的表å•åQ?nbsp;
<FORM ACTION="/cgi-bin/collect.cgi" METHOD="POST" >
<P>误‚¾“入您的留a€åQˆæœ€å¤?0个嗽W¦ï¼‰åQ?lt;BR>
<INPUT NAME="data" SIZE="60" MAXLENGTH="80" ><BR>
<INPUT TYPE="SUBMIT" VALUE="¼‹®å®š">
</FORM >
   事实上,˜q™ä¸ª½E‹åºåªèƒ½ä½œäؓ例ååQŒæ˜¯ä¸èƒ½å¤Ÿæ£å¼çš„ä½¿ç”¨çš„ã€‚å®ƒæ¼æŽ‰äº†å¾ˆå…³é”®çš„ä¸€ä¸ªé—®é¢˜ï¼šå½“æœ‰å¤šä¸ªç”¨æˆ·åŒæ—¶åƒæ–‡ä»¶å†™å…¥æ•°æ®æ˜¯åQŒè‚¯å®šä¼šæœ‰é”™è¯¯å‘生。而对于一个这æ ïLš„½E‹åºè€Œè¨€åQŒæ–‡ä»¶è¢«åŒæ—¶å†™å…¥çš„å‡ çŽ‡æ˜¯å¾ˆå¤§çš„ã€‚å› æ¤ï¼Œåœ¨æ¯”较æ£å¼çš„留言版程åºä¸åQŒéƒ½éœ€è¦åšä¸€äº›æ›´å¤šçš„考虑åQŒæ¯”å¦‚åŠ å…¥ä¸€ä¸ªä¿¡å·é‡åQŒæˆ–者是借助于一个钥匙文件ç‰ã€‚å› ä¸ºé‚£åªæ˜¯¾~–程的技巧问题,在这儿就ä¸å¤šè¯´äº†ã€?br />
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void main()
{
printf("Content-type:text/html\n\n");
printf("hello world!");
fflush(stdout);
}
处ç†get代ç
#include <stdio.h>
#include <stdlib.h>
int zmain(void)
{char *data;
long m,n;
printf("%s%c%c\n","Content-Type:text/html;charset=iso-8859-1",13,10);
printf("<TITLE>Multiplication results</TITLE>\n");
printf("<H3>Multiplication results</H3>\n");
data = getenv("QUERY_STRING");
if(data == NULL)
printf("<P>Error! Error in passing data from form to script.");
else if(sscanf(data,"m=%ld&n=%ld",&m,&n)!=2)
printf("<P>Error! Invalid data. Data must be numeric.");
else
printf("<P>The product of %ld and %ld is %ld.",m,n,m*n);
return 0;
}
处ç†post代ç
#include<stdio.h>
#include<stdlib.h>
void main()
{
int i,n;
printf("Content-type:text/html\n\n");
n=0;
if(getenv("CONTENT_LENGTH"))
n=atoi(getenv("CONTENT_LENGTH"));
printf("%d",n);
for(i=0;i<n;i++)
putchar(getchar());
putchar('\n');
fflush(stdout);
}
˜q˜æ˜¯ä»£ç
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* 转æ¢å‡½æ•°å£°æ˜Ž */
int htoi(char *);
/* ä¸Õd‡½æ•?*/
void zmain() {
int i,n;
char c;
printf ("Content-type: text/html\n\n");
n=0;
if (getenv("CONTENT_LENGTH"))
n=atoi(getenv("CONTENT_LENGTH"));
for (i=0; i<n;i++){
int is_eq=0; //åˆ¤æ–æ˜¯å¦æœ‰ç‰äºŽå·ã€?br />
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);
}
/* 转æ¢ä¸ºå°å†?*/
int islower (int ch )
{
return (unsigned int) (ch - 'a') < 26u;
}
/* convert hex string to int 16˜q›åˆ¶è½¬æ¢æˆ?0˜q›åˆ¶ */
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'));
}
#include<stdio.h>
#include<stdlib.h>
void zzzmain()
{
int i,n;
printf("Content-type:text/html\n\n");
n=0;
if(getenv("CONTENT_LENGTH"))
n=atoi(getenv("CONTENT_LENGTH"));
printf("%d",n);
for(i=0;i<n;i++)
putchar(getchar());
putchar('\n');
fflush(stdout);
}