mirror of
https://github.com/akheron/jansson.git
synced 2025-04-05 05:25:04 +00:00
Avoid integer overflows with very long strings
This commit is contained in:
parent
8dc3233f3b
commit
d544852ff6
2 changed files with 8 additions and 1 deletions
|
@ -249,6 +249,13 @@ int hashtable_set(hashtable_t *hashtable,
|
|||
/* offsetof(...) returns the size of pair_t without the last,
|
||||
flexible member. This way, the correct amount is
|
||||
allocated. */
|
||||
|
||||
size_t len = strlen(key);
|
||||
if(len > (size_t)-1 - offsetof(pair_t, key)) {
|
||||
/* Avoid an overflow if the key is very long */
|
||||
return -1;
|
||||
}
|
||||
|
||||
pair = jsonp_malloc(offsetof(pair_t, key) + strlen(key) + 1);
|
||||
if(!pair)
|
||||
return -1;
|
||||
|
|
|
@ -173,7 +173,7 @@ int utf8_check_string(const char *string, size_t length)
|
|||
return 0;
|
||||
else if(count > 1)
|
||||
{
|
||||
if(i + count > length)
|
||||
if(count > length - i)
|
||||
return 0;
|
||||
|
||||
if(!utf8_check_full(&string[i], count, NULL))
|
||||
|
|
Loading…
Add table
Reference in a new issue