app开发者平台在数字化时代的重要性与发展趋势解析
659
2022-09-05
C# 实现readUTF()函数
某网站的数据输出到前端,先用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);}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~