一、自定義Base16編碼原理 Base16編碼跟Base64編碼原理上有點不同,當然前面轉換是一樣的,都是是將輸入的字元串根據預設編碼轉換成一個位元組序列,而這個位元組序列裡面其實就是存的ASCII碼,其次,將每個ASCII碼轉換成8位二進位,每個八位二進位拆分成4位一組的二進位,然後將每4位一組的二 ...
一、自定義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">自定義Base16編碼數組,16個元素,可以為數字、字元、特殊符號,若不填,使用預設的Base16編碼數組,解碼與編碼的Base16編碼數組一樣</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">自定義Base16編碼數組,16個元素,可以為數字、字元、特殊符號,若不填,使用預設的Base16編碼數組,解碼與編碼的Base16編碼數組一樣</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編碼解碼,其實很簡單了,原理也很簡單,適合初學者學習體驗,當然這個編碼解碼可以擴展,如果哪位高手或者前輩有新的思路或者想法,請告知,謝謝。