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 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
感谢大佬
[***.8.128.20]2024年04月23日 06时49分41秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
【学习笔记】对vanilla的一些个人理解
2019-04-30
【解决错误】The size of tensor a (8) must match the size of tensor b (64) at non-singleton dimension 1
2019-04-30
word文档中实现目录索引中标题加粗,前导符和页码不加粗
2019-04-30
“学硕” VS “专硕”
2019-04-30
【NLP学习笔记】知识图谱阅读笔记及其心得
2019-04-30
【工具使用】新版CSDN-markdown编辑器使用指南
2019-04-30
《知识图谱》阅读笔记(六)
2019-04-30
【NLP学习笔记】中文分词(Word Segmentation,WS)
2019-04-30
【NLP学习笔记】词性标注(Part-of-speech Tagging, POS)
2019-04-30
《知识图谱》阅读笔记(七)
2019-04-30
《知识图谱》阅读笔记(九)
2019-04-30
【超越白皮书7】你需要知道关于ETH2.0的几个事实
2019-04-30
超越白皮书8:穿云而过的闪电网络
2019-04-30
AMM做市无常损失对冲分析系列(一)—— 损益及期权对冲模型构建
2019-04-30
JS中document对象和window对象有什么区别
2019-04-30
【python练习题】遍历1
2019-04-30
【matlab】显示图片且下方显示文字
2019-04-30
关于greater<int>以及类模板的一些理解
2019-04-30