NodeJS,basE91,&little endian

我怎么会得到解码使用NodeJS从basE91string到可读文本?

8D7Hh-9D*.n-!DZrG-#DE-$DD-%DC-sl-tl-BEp2m-CE^Ul-DE}CH-EEE-FED-GEC-<l-=l-hE(.K-iEvqS-jEB-kEB-lEB-mEB-Rm-Sm-%E!{Q-&EDgN-(EG:K-)EE-*EE-+EB-xm-ym-GF{}U-HF()Q-IFt%D-JFE-KFB-LFD-[m-]m-mF;JG-nF7]Q-oF2-pFB-qFC-rFB-Wn-Xn-+FD-,FE-.FB- FE-:FD-;FC-2n-3n- 

*编辑*

使用basE91表,我设法将上面的string转换成hexstring

Hexstring

 5668557210457684246110336890114713568693668683768671151081161086669112501096769948510868691567726969697069687169676010861108104694046751056911811383106696610769661086966109696682109810937693312381386968103784069715875416969426969436966120109121109717012312585727040418173701637687470697570667670689110993109109705974711107055938111170501127066113706711470668711088104370684470694670664770695870685970675011051110 

然后我把它喂入缓冲区

 var buf = new Buffer(hex, 'hex'); console.log(buf.toString('utf8')); 

这给了我:

 VhUr►Ev?$a►3h?◄G‼V??f??v?q§►?▬►?f?↕P►?v?Hhi↕Vw&???♠??▬?va►?♦i@Fu►V?↑◄81♠if►v?if►??h! ?►??1#?8ih►7?♠?§?T▬??&??6?a ►?!►?↨☺#↕XW'♦♦↑↨7☺▬7htpiupfvph?►?1 ►?♣?G◄►p U??◄↨♣☺↕pf◄7♠q¶pf??►CphDpiFpfGpiXphYpgP◄♣◄► 

我怎么把它变成我可以使用的东西? 我怀疑它是一个JSON对象…

在这个讨论中,有两个非常独立的问题正在被混淆。

如何使用Javascript / NodeJS / CommnJS解码basE91?

这就是你的问题似乎一目了然,你在这方面已经得到 各种 反应 。 答案似乎是:没有现有的解决scheme,但basE91是小而简单的,你应该能够将它移植到JS,没有太多的麻烦。

你的第二个不太明确的问题似乎是:

我怎么能反向工程师Ultima的游戏服务器通信协议?

你提到你的“basE91 LE”string来自于一个MMO游戏服务器,而这个关于Ultima的Lord的论坛几乎是“basE91 little endian”的唯一其他命中。 (加上它看起来像你在几天前张贴在那里 ) 。 各种 注意到 ,你张贴的数据是不是普通的香草basE91。 BasE91有一个明确定义的字符集,“ - ”和“ '(空间)不在其中,但都出现在你的数据中。 你在评论中提到,你认为' - '被用作分隔符,如果提前提供了更多的信息,回答第二个问题会更容易。

关于这个问题的一些说明:

  • BasE91使用一个标准的编码表。 如果你正在制作一个在线游戏,并想混淆你的stream量,那么使用一个不同的或混乱的表是微不足道的。 这将解释出现在您的数据中的不合法basE91的字符。 另外,从这个论坛的这个post看起来是完全一样的:一个不同的de /编码表。 您是否尝试过使用该表来手动解码部分数据,并查看它是否有意义?

  • 您请求转换为“可读文本”,但是basE91用于传输二进制数据,所以不清楚为什么要用纯文本。 即使假定它是编码文本,也有各种常见的方式来编码纯文本和解码的数据似乎并没有这样做 。 更可能的是,数据是实际的二进制数据,而在一个非常真实的意义上,basE91 文本表示。 如果没有更多关于您期望的输出的信息,就很难知道如何将其转换为文本。 这是一个1像素透明gif的basE91编码:

     JaQGWo*HBtAARDBtB"B"B"S|QtAAAA$M)Bc4v(#AsAAABtAACABtlBLHBtd 

    可以将其转换为可读文本吗? 你提到你认为它是JSON,你能给我们一些提示,说明你为什么这么想吗? (再次,为什么使用纯文本的二进制编码器?)

  • 从同一个论坛post工作,这听起来像你正在与一系列的5位坐标,所以也许这些数字是你在找什么? 然而,还有更多的难题,因为这些basE91组编码不同的大小编号。 机智(警告墙上的不可思议的文字):

     echo '8D7Hh-9D*.n-!DZrG-#DE-$DD-%DC-sl-tl-BEp2m-CE^Ul-DE}CH-EEE-FED-GEC-<l-=l-hE(.K-iEvqS-jEB-kEB-lEB-mEB-Rm-Sm-%E!{Q-&EDgN-(EG:K-)EE-*EE-+EB-xm-ym-GF{}U-HF()Q-IFt%D-JFE-KFB-LFD-[m-]m-mF;JG-nF7]Q-oF2-pFB-qFC-rFB-Wn-Xn-+FD-,FE-.FB- FE-:FD-;FC-2n-3n-' \ | while IFS='' read -d - a; do echo -n "'$a' => "; echo -n "$a" \ | ./base91 -d | hexdump | head -1 | cut -d ' ' -f 2-; done # head and cut are easier that understanding hexdump's formatting system '8D7Hh' => 4d 01 57 84 '9D*.n' => 4e a1 3b 9f '!DZrG' => 4f 41 ec 19 '#DE' => 50 81 '$DD' => 51 61 '%DC' => 52 41 'sl' => 53 'tl' => 54 'BEp2m' => 6d 61 6b 9a 'CE^Ul' => 6e e1 ed 94 'DE}CH' => 6f c1 21 1c 'EEE' => 70 81 'FED' => 71 61 'GEC' => 72 41 '<l' => 73 '=l' => 74 'hE(.K' => 8d 61 3b 2b 'iEvqS' => 8e a1 e3 49 'jEB' => 8f 21 'kEB' => 90 21 'lEB' => 91 21 'mEB' => 92 21 'Rm' => 93 'Sm' => 94 '%E!{Q' => ad 01 da 43 '&EDgN' => ae 61 6c 35 '(EG:K' => af 81 4a 2b ')EE' => b0 81 '*EE' => b1 81 '+EB' => b2 21 'xm' => b3 'ym' => b4 'GF{}U' => cd c1 f3 53 'HF()Q' => ce e1 0d 43 'IFt%D' => cf 01 e9 0e 'JFE' => d0 81 'KFB' => d1 21 'LFD' => d2 61 '[m' => d3 ']m' => d4 'mF;JG' => ed c1 6f 18 'nF7]Q' => ee 21 ac 43 'oF2' => ef c1 'pFB' => f0 21 'qFC' => f1 41 'rFB' => f2 21 'Wn' => f3 'Xn' => f4 '+FD' => 0d 62 ',FE' => 0e 82 '.FB' => 0f 22 ' FE' => 71 ':FD' => 11 62 ';FC' => 12 42 '2n' => 13 '3n' => 14 

    那里肯定有一个模式,如果你眯起来的话,甚至看起来很小端。 但他们对我来说没有任何意义,他们看起来对你是否理智?

在github上有非常紧凑的basE91编码器/解码器的Java实现 。 我认为这应该很容易转化为JS。

直接链接到源文件 。

简单的回答是,在node.js中没有简单/快捷的方法来做到这一点(显然目前没有模块)。

添加@bryanmac的注释,使用base91作为起点(主源文件只有160行,包括版权!),你可以将数据存储在一个node.js缓冲区,并且一旦从base91转换为字节,使用内置的node.js方法转换为string。

对于“如何使用Javascript / NodeJS / CommnJS解码basE91?”

我将原来的basE91移植到JavaScript中,目前支持StringBufferStream 。 您可以尝试一下: Equim-chan / base91

首先我们需要一个表格:

 const table = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789!#$%&()*+,./:;<=>?@[]^_`{|}~"'; 

encode的核心部分:

 // `raw` is the input, asserted as `Buffer` const len = raw.length; let ret = ''; let n = 0; let b = 0; for (let i = 0; i < len; i++) { b |= raw[i] << n; n += 8; if (n > 13) { let v = b & 8191; if (v > 88) { b >>= 13; n -= 13; } else { v = b & 16383; b >>= 14; n -= 14; } ret += table[v % 91] + table[v / 91 | 0]; } } if (n) { ret += table[b % 91]; if (n > 7 || b > 90) ret += table[b / 91 | 0]; } return ret; // basE91 encoded string 

decode的核心部分:

 // `raw` is the input, asserted as `String` const len = raw.length; const ret = []; let b = 0; let n = 0; let v = -1; for (let i = 0; i < len; i++) { const p = table.indexOf(raw[i]); if (p === -1) continue; if (v < 0) { v = p; } else { v += p * 91; b |= v << n; n += (v & 8191) > 88 ? 13 : 14; do { ret.push(b & 0xff); b >>= 8; n -= 8; } while (n > 7); v = -1; } } if (v > -1) { ret.push((b | v << n) & 0xff); } return Buffer.from(ret); // basE91 decoded Buffer 

以上是针对标准的basE91编码/解码,但正如@blahdiblah提到的,显然你从服务器接收到一个非标准的basE91编码的string(没有*也没有 在标准表中)。