Commit 29d6c4ac authored by Marko Mikulicic's avatar Marko Mikulicic

Fix url path parsing

The url parser had two bugs:
- `http://example.com` -> `GET // HTTP/1.1`
- `foo://bar/baz` -> path is `"baz"` instead of `"/baz"`

Now the path returned by  `mg_http_common_url_parse` always
starts with `/`.

Closes cesanta/mongoose#631

PUBLISHED_FROM=f56ed97361ca14ee31d6ed26cf7afe5cd11e0dc5
parent 8148b6d0
...@@ -7540,7 +7540,6 @@ static int mg_http_common_url_parse(const char *url, const char *schema, ...@@ -7540,7 +7540,6 @@ static int mg_http_common_url_parse(const char *url, const char *schema,
return -1; return -1;
} }
if (*url == '/') { if (*url == '/') {
url++;
break; break;
} }
if (*url == ':') *port_i = addr_len; if (*url == ':') *port_i = addr_len;
...@@ -7632,7 +7631,7 @@ struct mg_connection *mg_connect_http(struct mg_mgr *mgr, ...@@ -7632,7 +7631,7 @@ struct mg_connection *mg_connect_http(struct mg_mgr *mgr,
/* If the port was addred by us, restore the original host. */ /* If the port was addred by us, restore the original host. */
if (port_i >= 0) addr[port_i] = '\0'; if (port_i >= 0) addr[port_i] = '\0';
mg_printf(nc, "%s /%s HTTP/1.1\r\nHost: %s\r\nContent-Length: %" SIZE_T_FMT mg_printf(nc, "%s %s HTTP/1.1\r\nHost: %s\r\nContent-Length: %" SIZE_T_FMT
"\r\n%s\r\n%s", "\r\n%s\r\n%s",
post_data == NULL ? "GET" : "POST", path, addr, post_data == NULL ? "GET" : "POST", path, addr,
post_data == NULL ? 0 : strlen(post_data), post_data == NULL ? 0 : strlen(post_data),
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment