当前位置: 移动技术网 > IT编程>开发语言>c# > c#中自定义Base16编码解码的方法示例

c#中自定义Base16编码解码的方法示例

2019年07月18日  | 移动技术网IT编程  | 我要评论

一、自定义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;
  }

c# 16进制转换为base64字符串

matchcollection mc = regex.matches(retrunvalue.tostring(), "[a-f0-9]{2}"); 
byte[] bytes = new byte[mc.count]; 
for (int i = 0; i < mc.count; i++) 
{ 
  bytes[i] = byte.parse(mc[i].value, system.globalization.numberstyles.hexnumber); 
} 
 
retrunvalue = convert.tobase64string(bytes); 

总结

我写的这个base16编码解码,其实很简单了,原理也很简单,适合初学者学习体验,当然这个编码解码可以扩展,如果哪位高手或者前辈有新的思路或者想法,请告知,谢谢。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网