Node.js: using low-case header names as key in req.headers.
Node.js modules (body-parser, row-body) search low-cased names ('content-length', 'content-type' etc.) to properly assemble request body. This closes #246 issue on GitHub.
This commit is contained in:
parent
704529e4b1
commit
c6e96647a1
1 changed files with 17 additions and 4 deletions
|
@ -376,17 +376,30 @@ Unit::create_headers(nxt_unit_request_info_t *req, napi_value request)
|
|||
}
|
||||
|
||||
|
||||
inline char
|
||||
lowcase(char c)
|
||||
{
|
||||
return (c >= 'A' && c <= 'Z') ? (c | 0x20) : c;
|
||||
}
|
||||
|
||||
|
||||
inline void
|
||||
Unit::append_header(nxt_unit_field_t *f, napi_value headers,
|
||||
napi_value raw_headers, uint32_t idx)
|
||||
{
|
||||
const char *name;
|
||||
char *name;
|
||||
uint8_t i;
|
||||
napi_value str, vstr;
|
||||
|
||||
name = (const char *) nxt_unit_sptr_get(&f->name);
|
||||
name = (char *) nxt_unit_sptr_get(&f->name);
|
||||
|
||||
str = create_string_latin1(name, f->name_length);
|
||||
|
||||
for (i = 0; i < f->name_length; i++) {
|
||||
name[i] = lowcase(name[i]);
|
||||
}
|
||||
|
||||
vstr = set_named_property(headers, name, f->value, f->value_length);
|
||||
str = create_string_latin1(name, f->name_length);
|
||||
|
||||
set_element(raw_headers, idx * 2, str);
|
||||
set_element(raw_headers, idx * 2 + 1, vstr);
|
||||
|
|
Loading…
Reference in a new issue