From c735b4663acad20c4d8ccd7a469de77927af22bb Mon Sep 17 00:00:00 2001 From: Jorge Chamorro Bieling Date: Mon, 18 Oct 2010 22:08:42 +0200 Subject: [PATCH] unbase64 skips over *any* illegal chars --- src/node_buffer.cc | 10 +++++++++- test/simple/test-buffer.js | 11 +++++++++++ 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/src/node_buffer.cc b/src/node_buffer.cc index 3f254081f5..bc9ef0426a 100644 --- a/src/node_buffer.cc +++ b/src/node_buffer.cc @@ -230,8 +230,16 @@ static const int unbase64_table[] = ,15,16,17,18,19,20,21,22,23,24,25,-1,-1,-1,-1,-1 ,-1,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40 ,41,42,43,44,45,46,47,48,49,50,51,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 + ,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 }; -#define unbase64(x) unbase64_table[(int)(x)] +#define unbase64(x) unbase64_table[(uint8_t)(x)] Handle Buffer::Base64Slice(const Arguments &args) { diff --git a/test/simple/test-buffer.js b/test/simple/test-buffer.js index 512aea5970..26ebd4798a 100644 --- a/test/simple/test-buffer.js +++ b/test/simple/test-buffer.js @@ -256,6 +256,17 @@ b = new Buffer(expectedWhite, 'base64'); assert.equal(quote.length, b.length); assert.equal(quote, b.toString('ascii', 0, quote.length)); +// check that the base64 decoder ignores illegal chars +var expectedIllegal = expected.slice(0, 60) + " \x80" + + expected.slice(60, 120) + " \xff" + + expected.slice(120, 180) + " \x00" + + expected.slice(180, 240) + " \x98" + + expected.slice(240, 300) + "\x03" + + expected.slice(300, 360) +b = new Buffer(expectedIllegal, 'base64'); +assert.equal(quote.length, b.length); +assert.equal(quote, b.toString('ascii', 0, quote.length)); + assert.equal(new Buffer('', 'base64').toString(), ''); assert.equal(new Buffer('K', 'base64').toString(), '');