Better fix for HTTP header decode (#2491)

See https://github.com/nodemcu/nodemcu-firmware/issues/2482
This commit is contained in:
Nathaniel Wesley Filardo 2018-09-21 10:57:52 +01:00 committed by Marcel Stör
parent 21b77bd668
commit 0e103a39dd
1 changed files with 4 additions and 7 deletions

View File

@ -210,7 +210,7 @@ static void ICACHE_FLASH_ATTR http_connect_callback( void * arg )
char ua_header[32] = ""; char ua_header[32] = "";
int ua_len = 0; int ua_len = 0;
if (os_strstr( req->headers, "User-Agent:" ) == NULL && os_strstr( req->headers, "user-agent:" ) == NULL) if (strcasestr( req->headers, "User-Agent:" ) == NULL )
{ {
os_sprintf( ua_header, "User-Agent: %s\r\n", "ESP8266" ); os_sprintf( ua_header, "User-Agent: %s\r\n", "ESP8266" );
ua_len = strlen(ua_header); ua_len = strlen(ua_header);
@ -218,7 +218,7 @@ static void ICACHE_FLASH_ATTR http_connect_callback( void * arg )
char * host_header = ""; char * host_header = "";
int host_len = 0; int host_len = 0;
if ( os_strstr( req->headers, "Host:" ) == NULL && os_strstr( req->headers, "host:" ) == NULL) if ( strcasestr( req->headers, "Host:" ) == NULL )
{ {
int max_header_len = 9 + strlen(req->hostname); // 9 is fixed size of "Host:[space][cr][lf]\0" int max_header_len = 9 + strlen(req->hostname); // 9 is fixed size of "Host:[space][cr][lf]\0"
if ((req->port == 80) if ((req->port == 80)
@ -328,10 +328,7 @@ static void ICACHE_FLASH_ATTR http_disconnect_callback( void * arg )
{ {
http_status = atoi( req->buffer + strlen( version_1_0 ) ); http_status = atoi( req->buffer + strlen( version_1_0 ) );
char *locationOffset = (char *) os_strstr( req->buffer, "Location:" ); char *locationOffset = (char *) strcasestr( req->buffer, "Location:" );
if ( locationOffset == NULL ) {
locationOffset = (char *) os_strstr( req->buffer, "location:" );
}
if ( locationOffset != NULL && http_status >= 300 && http_status <= 308 ) { if ( locationOffset != NULL && http_status >= 300 && http_status <= 308 ) {
if (req->redirect_follow_count < REDIRECTION_FOLLOW_MAX) { if (req->redirect_follow_count < REDIRECTION_FOLLOW_MAX) {
@ -414,7 +411,7 @@ static void ICACHE_FLASH_ATTR http_disconnect_callback( void * arg )
body = body + 4; body = body + 4;
} }
if ( os_strstr( req->buffer, "Transfer-Encoding: chunked" ) || os_strstr( req->buffer, "transfer-encoding: chunked" ) ) if ( strcasestr( req->buffer, "Transfer-Encoding: chunked" ) )
{ {
int body_size = req->buffer_size - (body - req->buffer); int body_size = req->buffer_size - (body - req->buffer);
char chunked_decode_buffer[body_size]; char chunked_decode_buffer[body_size];