自定义Base16加密
Posted 超越时光的速度
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自定义Base16加密相关的知识,希望对你有一定的参考价值。
自定义Base16加密原理
Base16加密跟Base64加密原理上有点不同,当然前面转换是一样的,都是是将输入的字符串根据默认编码转换成一个字节序列,而这个字节序列里面其实就是存的ASCII码,其次,将每个ASCII码转换成8位二进制,每个八位二进制拆分成4位一组的二进制,然后将每4位一组的二进制转换成十进制, 最后,根据十进制的数字索引密文下标的字符,将这些字符串联起来就是加密的字符串。
例子:abc
ASCII码: 97 98 99
二进制: 01100001 01100010 01100011
拆分成四位一组: 0110 0001 0110 0010 0110 0011
十进制: 6 1 6 2 6 3
根据十进制索引密文下标中的字符,上代码:
/// <summary> /// 自定义Base16加密 /// </summary> /// <param name="str">加密字符串</param> /// <param name="autoCode">自定义密文,16个元素,可以为数字、字符、特殊符号,若不填,使用默认的密文,解密与加密的密文一样</param> /// <returns></returns> public static string AutoBase16Encrypt(string str, string[] autoCode) { string innerStr = string.Empty; StringBuilder strEn = new StringBuilder(); if (autoCode == null || autoCode.Length < 16) autoCode = new string[] { "a", "2", "B", "g", "E", "5", "f", "6", "C", "8", "o", "9", "Z", "p", "k", "M" }; System.Collections.ArrayList arr = new System.Collections.ArrayList(System.Text.Encoding.Default.GetBytes(str)); for (int i = 0; i < arr.Count; i++) { byte data = (byte)arr[i]; int v1 = data >> 4; strEn.Append(autoCode[v1]); int v2 = ((data & 0x0f) << 4) >> 4; strEn.Append(autoCode[v2]); } return strEn.ToString(); }
自定义Base16解密原理
其实解密原理也很简单了,首先,将加密的字符串拆分成字符,其次,根据字符寻找到第一个和第二个字符的下标值。将第一个下标值转换成8位二进制,然后左移4位,与第二个字符的下标值合成一个字节,保存在字节数组里,最后,将保存好的字节数组根据默认编码转换成字符串。(解密我就不详加解释了)
/// <summary> /// 自定义Base16解密 /// </summary> /// <param name="str">解密字符串</param> /// <param name="autoCode">自定义密文,16个元素,可以为数字、字符、特殊符号,若不填,使用默认的密文,解密与加密的密文一样</param> /// <returns></returns> public static string AutoBase16Decrypt(string str, string[] autoCode) { int k = 0; string dnStr = string.Empty; int strLength = str.Length; if (autoCode == null || autoCode.Length < 16) autoCode = new string[] { "a", "2", "B", "g", "E", "5", "f", "6", "C", "8", "o", "9", "Z", "p", "k", "M" }; byte[] data = new byte[strLength / 2]; for (int i = 0, j = 0; i < data.Length; i++, j++) { byte s = 0; int index1 = autoCode.ToList().IndexOf(str[j].ToString()); j += 1; int index2 = autoCode.ToList().IndexOf(str[j].ToString()); s = (byte)(s ^ index1); s = (byte)(s << 4); s = (byte)(s ^ index2); data[k] = s; k++; } dnStr = Encoding.Default.GetString(data); return dnStr; }
Base16密文
最后说一下这个密文,这个密文呢,是一个字符串数组,元素总数不能小于16个,当然超过16个元素,也用不上,这16个字符完全自定义,这个比较灵活,最后给大家看一个随机密文的函数。
/// <summary> /// 随机密文 /// </summary> /// <returns></returns> public string[] RandomEncrypt() { string[] code = new string[16]; Random random = new Random(); int j = 0; for (int i = 0; 1 < 2; i++) { char ch = (char)random.Next(1, 128); if (code.ToList().IndexOf(ch.ToString()) < 0 && (( ch >= ‘0‘ && ch <= ‘9‘) || (ch >= ‘a‘ && ch <= ‘z‘) || (ch >= ‘A‘ && ch <= ‘Z‘))) { code[j] = ch.ToString(); j++; } if (!Array.Exists(code, string.IsNullOrEmpty) && code.Length == 16) break; } return code; }
总结:我写的这个Base16加密解密,其实很简单了,原理也很简单,适合初学者学习体验,当然这个加密解密可以扩展,如果哪位高手或者前辈有新的思路或者想法,请告知,谢谢。
以上是关于自定义Base16加密的主要内容,如果未能解决你的问题,请参考以下文章
Base64加密解密不一致导致AES加密报出javax.crypto.IllegalBlockSizeException: Input length must be multiple of 16 wh