Sto cercando di analizzare la seguente risposta HTTP:C principianti: stringa parsing
HTTP/1.1 200 OK
Date: Tue, 06 Dec 2011 11:15:21 GMT
Server: Apache/2.2.14 (Ubuntu)
X-Powered-By: PHP/5.3.2-1ubuntu4.9
Vary: Accept-Encoding
Content-Encoding: gzip
Content-Length: 48
Content-Type: text/html
��(�ͱ���I�O����H�����ч��
�4�@�B�$���S
Voglio estrarre "48" e il contenuto binario.
Ecco che cosa ho provato sofar:
//char* str contains the response
char * pch;
printf ("Splitting response into tokens:\n");
pch = strtok (str,"\r\n");
while (pch != NULL)
{
printf ("%s\n",pch);
pch = strtok (NULL, "\r\n");
}
Ma io sono un po 'bloccato ormai ... Ogni aiuto è molto apprezzato.
edit:
Ecco quello che ho fatto sofar:
char* pch;
char* pch2;
pch=strstr(buf,"Content-Length:");
pch2=strstr(pch,"\r\n");
Come posso ottenere la punta tra questi due puntatori?
Edit: Soluzione:
char* pch;
char* pch2;
pch=strstr(buf,"Content-Length:");
int i=0;
char contLen[20];
for(i=0;i<20;i++){
char next=pch[strlen("Content-Length:")+i];
if(next=='\r' || next=='\n'){
break;
}
contLen[i]=next;
}
printf("%d\n",atoi(contLen));
Puoi controllare http://curl.haxx.se/libcurl/c/ e l'opzione 'CURLOPT_WRITEHEADER' – Cyclonecode
Voglio evitare di usare CURL. Sto facendo tutto usando le prese ... – Eamorr