C# 实现readUTF()函数
发布日期:2021-06-30 17:17:08 浏览次数:2 分类:技术文章

本文共 668 字,大约阅读时间需要 2 分钟。

某网站的数据输出到前端,先用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);}

转载地址:https://leftfist.blog.csdn.net/article/details/102620144 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:在WIN7中用maven将spring boot项目远程部署到Linux虚拟机的docker容器
下一篇:linux的文件和文件夹操作

发表评论

最新留言

感谢大佬
[***.8.128.20]2024年04月23日 06时49分41秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章