string与byte[]之间的转换
在使用.NET加密类的时候,会经常用到string与byte[]之间的转换。
首先引用System.Text命名空间,然后
UnicodeEncoding unicode=new UnicodeEncoding();
byte[] byteA;
//byte[] -> string
byteA=unicode.GetBytes(textBox1.Text);
//string -> byte[]
textBox1.Text=unicode.GetString(byteA);
最后,说明一下System.Text命名空间里面,ASCIIEncoding是处理不了中文的,会出现乱码的;而UTF8Encoding存在不确定因素,如果这个字符用1个字节能存储下(英文或数字)那么它就用1个字节,如果这个字符用2个字节才能存储下(汉字、韩文等)那么它就用2个字节,这样加解密的话,就容易出现字节位数对不上的问题;所以在使用System.Security.Cryptograph时一定要用UnicodeEncoding编码!标准Unicode都用2个字节来表示1个字符,而UTF8是为了网页浏览节省空间而专门设计的
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步