某网站的数据输出到前端,先用Base64进行加密,包裹一层;解开以后,是二进制数据。那要解开这个二进制数据,就只能按照该网站的算法,读取若干个字节,就是某个数据;接着再读取若干个字节,是另一个数据。然后这个算法本身,虽然写在JS文件里,但它又做了一定的混淆。本来读别人的代码就不容易理解,混淆了以后,就更加难懂了。
我理解这样做的好处在哪里。第一个肯定就是保密了。第二个是数据比较紧凑,体积小,利于提高传输性能。不过这种数据,一般都是数字,因为读取出字节,本身就是数字。如果是字符编码,还要做转换才能最终看到正确的字符串。
当然传输字符串也是可以的。读取的套路是这样的:先读2个字节,16位。它们代表的是字符串的长度(单位为字节byte)。获得这个长度以后就简单了,读取这些字节,按照一定的编码进行转换,就能得到相应的字符串。通常,这个函数名曰:readUTF()。C#里没有现成的,但也不难实现。俺给出一个:
using System.IO;
using System.Text;
string readUTF(BinaryReader br)
{
ushort len = br.ReadUInt16();
byte[] bs = new byte[len];
int i = 0;
while (i < len)
{
bs[i] = br.ReadByte();
i++;
}
return Encoding.UTF8.GetString(bs);
}