crabs_firewall-3.0.1 ©2005-2011 - Christophe CAZAJUS (crabs-mettre_le_signe_at-crabs-world.com)
1 /* 2 **============================================================================= 3 ** crabs_firewall-3.0.1 : Firewall-Masquerade avec interface http 4 ** Copyright (C) 2005-2011 : Christophe CAZAJUS (crabs-mettre_le_signe_at-crabs-world.com) 5 ** 6 ** Ce source fait partie d'un projet logiciel libre. Vous pouvez le distribuer 7 ** et/ou le modifier en respectant les termes de la GNU General Public License 8 ** version 2 ou (suite a votre propre choix) une version ulterieure. 9 ** 10 ** Ce programme est distribue dans l'espoir qu'il puisse etre utile, mais 11 ** sans aucune garantie, meme si il est associe a un produit qui vous en 12 ** propose une. Conformez-vous a la GNU General Public License pour avoir 13 ** plus de precisions. 14 ** 15 ** L'auteur ne peut etre tenu responsable de l'utilisation faite des 16 ** composantes associees a ce projet (en partie ou dans leur totalite). 17 ** 18 ** Une copie du fichier de la GNU GPL est fournie dans le repertoire DOC 19 ** de ce projet sous le nom gnu_gpl.txt 20 ** 21 **============================================================================= 22 */ 23 #include <sys/types.h> 24 #include <strings.h> 25 #include <iostream> 26 #include <stdlib.h> 27 #include "cgi.h" 28 #include "cgi_var.H" 29 using namespace std ; 30 31 void Cgi::decode_post_url() 32 { 33 const char* clen = env( "CONTENT_LENGTH" ) ; 34 if ( !clen ) return ; 35 int len = atoi( clen ) + 1 ; 36 char* b = new char[len] ; 37 cin >> b ; 38 39 p = new CgiVar ; 40 char var[1024]; char val[1024]; 41 bool in_var = true; bool in_val = false ; size_t j=0 ; 42 for( size_t i=0; i<len;i++) 43 { 44 if ( b[i] == '=' ) // fin de variable 45 { 46 if ( in_var ) 47 { 48 var[j] = 0 ; 49 in_val = true; in_var = false; j=0 ; 50 continue ; 51 } 52 } 53 if ( b[i] == '&' ) // fin de valeur ou de variable 54 { 55 if ( in_var ) 56 var[j] = 0 , *val = 0 ; 57 else 58 val[j] = 0 ; 59 in_var = true ; in_val = false ; j = 0 ; 60 escape_caracteres( val ) ; p->ajouter( var, val ) ; 61 continue ; 62 } 63 if ( b[i] == '+' ) 64 { 65 if ( in_var ) var[j++] = ' ' ; 66 if ( in_val ) val[j++] = ' ' ; 67 } 68 else 69 { 70 if ( in_var ) var[j++] = b[i] ; 71 if ( in_val ) val[j++] = b[i] ; 72 } 73 } 74 if ( *var ) 75 { 76 if ( in_var ) { var[j] = 0; *val = 0 ; } 77 if ( in_val ) val[j] = 0 ; 78 escape_caracteres( val ) ; p->ajouter( var, val ) ; 79 } 80 } 81
Date de génération : 22/09/2011 21:48