-
Notifications
You must be signed in to change notification settings - Fork 30.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Buffer.toString() cannot handle large indices #52298
Comments
The issue you're encountering is due to JavaScript's handling of integers beyond Number.MAX_SAFE_INTEGER (which is 2^53 - 1), resulting in the values being interpreted as negative when passed to Buffer.toString(). make sure that the start and end parameters passed to Buffer.toString() are within the range of safe integers. You can achieve this by performing bounds checking before calling Buffer.toString(). |
Sorry for being made an unclear comment on example code. I wrote INT_MAX < start but I think it would be correct to express it as 2^32-1. |
I see ! you may need to perform bounds checking before calling Buffer.toString() to ensure that the offsets are within the range of safe integers. This will help prevent the index out of range errors until a fix or enhancement is made to Buffer.toString(). Rest i think Node Js internal need to have a look on this. |
This should fix it in a non-breaking way: diff --git a/lib/buffer.js b/lib/buffer.js
index a8d07342e15..904f1fff6b3 100644
--- a/lib/buffer.js
+++ b/lib/buffer.js
@@ -820,12 +820,12 @@ Buffer.prototype.toString = function toString(encoding, start, end) {
else if (start >= len)
return '';
else
- start |= 0;
+ start = MathTrunc(start) || 0;
if (end === undefined || end > len)
end = len;
else
- end |= 0;
+ end = MathTrunc(end) || 0;
if (end <= start)
return ''; |
Thank you @targos ! |
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: #54553 Fixes: #52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: #54553 Fixes: #52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: nodejs#54553 Fixes: nodejs#52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: nodejs#54553 Fixes: nodejs#52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: nodejs#54553 Fixes: nodejs#52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: nodejs#54553 Fixes: nodejs#52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: #54553 Backport-PR-URL: #55213 Fixes: #52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]> Refs: #54553
Co-authored-by: Michaël Zasso <[email protected]> PR-URL: nodejs#54553 Fixes: nodejs#52298 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Jake Yuesong Li <[email protected]>
Version
14.17.3
Platform
23.4.0 Darwin Kernel Version 23.4.0
Subsystem
No response
What steps will reproduce the bug?
How often does it reproduce? Is there a required condition?
everytime
What is the expected behavior? Why is that the expected behavior?
Buffer.toString()
should be able to handle buffers smaller thankMaxLength
.What do you see instead?
index out of range error
Additional information
The bitwise or assignment (
|=
) operation ofBuffer.toString()
seems to be the cause of the error. If start or end parameter greater thanINT_MAX
is passed, the value changes to a negative number, resulting in an index out of range error.The text was updated successfully, but these errors were encountered: