亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? aes.cs

?? 用CSHARP實(shí)現(xiàn)的AES算法源代碼
?? CS
?? 第 1 頁 / 共 2 頁
字號:
      }

      for (int r = 1; r < 4; ++r)  // shift temp into State
      {
        for (int c = 0; c < 4; ++c)
        {
          this.State[r,c] = temp[ r, (c + r) % Nb ];
        }
      }
    }  // ShiftRows()

    private void InvShiftRows()
    {
      byte[,] temp = new byte[4,4];
      for (int r = 0; r < 4; ++r)  // copy State into temp[]
      {
        for (int c = 0; c < 4; ++c)
        {
          temp[r,c] = this.State[r,c];
        }
      }
      for (int r = 1; r < 4; ++r)  // shift temp into State
      {
        for (int c = 0; c < 4; ++c)
        {
          this.State[r, (c + r) % Nb ] = temp[r,c];
        }
      }
    }  // InvShiftRows()

    private void MixColumns()
    {
      byte[,] temp = new byte[4,4];
      for (int r = 0; r < 4; ++r)  // copy State into temp[]
      {
        for (int c = 0; c < 4; ++c)
        {
          temp[r,c] = this.State[r,c];
        }
      }
        
      for (int c = 0; c < 4; ++c)
      {
        this.State[0,c] = (byte) ( (int)gfmultby02(temp[0,c]) ^ (int)gfmultby03(temp[1,c]) ^
                                   (int)gfmultby01(temp[2,c]) ^ (int)gfmultby01(temp[3,c]) );
        this.State[1,c] = (byte) ( (int)gfmultby01(temp[0,c]) ^ (int)gfmultby02(temp[1,c]) ^
                                   (int)gfmultby03(temp[2,c]) ^ (int)gfmultby01(temp[3,c]) );
        this.State[2,c] = (byte) ( (int)gfmultby01(temp[0,c]) ^ (int)gfmultby01(temp[1,c]) ^
                                   (int)gfmultby02(temp[2,c]) ^ (int)gfmultby03(temp[3,c]) );
        this.State[3,c] = (byte) ( (int)gfmultby03(temp[0,c]) ^ (int)gfmultby01(temp[1,c]) ^
                                   (int)gfmultby01(temp[2,c]) ^ (int)gfmultby02(temp[3,c]) );
      }
    }  // MixColumns

    private void InvMixColumns()
    {
      byte[,] temp = new byte[4,4];
      for (int r = 0; r < 4; ++r)  // copy State into temp[]
      {
        for (int c = 0; c < 4; ++c)
        {
          temp[r,c] = this.State[r,c];
        }
      }
        
      for (int c = 0; c < 4; ++c)
      {
        this.State[0,c] = (byte) ( (int)gfmultby0e(temp[0,c]) ^ (int)gfmultby0b(temp[1,c]) ^
                                   (int)gfmultby0d(temp[2,c]) ^ (int)gfmultby09(temp[3,c]) );
        this.State[1,c] = (byte) ( (int)gfmultby09(temp[0,c]) ^ (int)gfmultby0e(temp[1,c]) ^
                                   (int)gfmultby0b(temp[2,c]) ^ (int)gfmultby0d(temp[3,c]) );
        this.State[2,c] = (byte) ( (int)gfmultby0d(temp[0,c]) ^ (int)gfmultby09(temp[1,c]) ^
                                   (int)gfmultby0e(temp[2,c]) ^ (int)gfmultby0b(temp[3,c]) );
        this.State[3,c] = (byte) ( (int)gfmultby0b(temp[0,c]) ^ (int)gfmultby0d(temp[1,c]) ^
                                   (int)gfmultby09(temp[2,c]) ^ (int)gfmultby0e(temp[3,c]) );
      }
    }  // InvMixColumns

    private static byte gfmultby01(byte b)
    {
      return b;
    }

    private static byte gfmultby02(byte b)
    {
      if (b < 0x80)
        return (byte)(int)(b <<1);
      else
        return (byte)( (int)(b << 1) ^ (int)(0x1b) );
    }

    private static byte gfmultby03(byte b)
    {
      return (byte) ( (int)gfmultby02(b) ^ (int)b );
    }

    private static byte gfmultby09(byte b)
    {
      return (byte)( (int)gfmultby02(gfmultby02(gfmultby02(b))) ^
                     (int)b );
    }

    private static byte gfmultby0b(byte b)
    {
      return (byte)( (int)gfmultby02(gfmultby02(gfmultby02(b))) ^
                     (int)gfmultby02(b) ^
                     (int)b );
    }

    private static byte gfmultby0d(byte b)
    {
      return (byte)( (int)gfmultby02(gfmultby02(gfmultby02(b))) ^
                     (int)gfmultby02(gfmultby02(b)) ^
                     (int)(b) );
    }

    private static byte gfmultby0e(byte b)
    {
      return (byte)( (int)gfmultby02(gfmultby02(gfmultby02(b))) ^
                     (int)gfmultby02(gfmultby02(b)) ^
                     (int)gfmultby02(b) );
    }

    private void KeyExpansion()
    {
      this.w = new byte[Nb * (Nr+1), 4];  // 4 columns of bytes corresponds to a word
    
      for (int row = 0; row < Nk; ++row)
      {
        this.w[row,0] = this.key[4*row];
        this.w[row,1] = this.key[4*row+1];
        this.w[row,2] = this.key[4*row+2];
        this.w[row,3] = this.key[4*row+3];
      }

      byte[] temp = new byte[4];

      for (int row = Nk; row < Nb * (Nr+1); ++row)
      {
        temp[0] = this.w[row-1,0]; temp[1] = this.w[row-1,1];
        temp[2] = this.w[row-1,2]; temp[3] = this.w[row-1,3];

        if (row % Nk == 0)  
        {
          temp = SubWord(RotWord(temp));
          
          temp[0] = (byte)( (int)temp[0] ^ (int)this.Rcon[row/Nk,0] );
          temp[1] = (byte)( (int)temp[1] ^ (int)this.Rcon[row/Nk,1] );
          temp[2] = (byte)( (int)temp[2] ^ (int)this.Rcon[row/Nk,2] );
          temp[3] = (byte)( (int)temp[3] ^ (int)this.Rcon[row/Nk,3] );
        }
        else if ( Nk > 6 && (row % Nk == 4) )  
        {
          temp = SubWord(temp);
        }
        
        // w[row] = w[row-Nk] xor temp
        this.w[row,0] = (byte) ( (int)this.w[row-Nk,0] ^ (int)temp[0] );
        this.w[row,1] = (byte) ( (int)this.w[row-Nk,1] ^ (int)temp[1] );
        this.w[row,2] = (byte) ( (int)this.w[row-Nk,2] ^ (int)temp[2] );
        this.w[row,3] = (byte) ( (int)this.w[row-Nk,3] ^ (int)temp[3] );
       
      }  // for loop
    }  // KeyExpansion()

    private byte[] SubWord(byte[] word)
    {
      byte[] result = new byte[4];
      result[0] = this.Sbox[ word[0] >> 4, word[0] & 0x0f ];
      result[1] = this.Sbox[ word[1] >> 4, word[1] & 0x0f ];
      result[2] = this.Sbox[ word[2] >> 4, word[2] & 0x0f ];
      result[3] = this.Sbox[ word[3] >> 4, word[3] & 0x0f ];
      return result;
    }

    private byte[] RotWord(byte[] word)
    {
      byte[] result = new byte[4];
      result[0] = word[1];
      result[1] = word[2];
      result[2] = word[3];
      result[3] = word[0];
      return result;
    }

    public  void Dump()
    {
      Console.WriteLine("Nb = " + Nb + " Nk = " + Nk + " Nr = " + Nr);
      Console.WriteLine("\nThe key is \n" + DumpKey() );
      Console.WriteLine("\nThe Sbox is \n" + DumpTwoByTwo(Sbox));
      Console.WriteLine("\nThe w array is \n" + DumpTwoByTwo(w));
      Console.WriteLine("\nThe State array is \n" + DumpTwoByTwo(State));
    }

    public string DumpKey()
    {
      string s = "";
      for (int i = 0; i < key.Length; ++i)
        s += key[i].ToString("x2") + " ";
      return s;
    }

    public string DumpTwoByTwo(byte[,] a)
    {
      string s ="";
      for (int r = 0; r < a.GetLength(0); ++r)
      {
        s += "["+r+"]" + " ";
        for (int c = 0; c < a.GetLength(1); ++c)
        {
          s += a[r,c].ToString("x2") + " " ;
        }
        s += "\n";
      }
      return s;
    }

  }  // class Aes
}  // ns AesLib

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美二区三区| 中文一区二区完整视频在线观看| 欧美在线观看你懂的| 欧美午夜理伦三级在线观看| 在线播放国产精品二区一二区四区| 欧美日韩高清一区二区| 日韩精品一区二区三区在线播放 | 2020国产精品自拍| www精品美女久久久tv| 国产精品―色哟哟| 亚洲综合色噜噜狠狠| 看电视剧不卡顿的网站| 日韩国产在线观看| 欧美一区二区视频免费观看| 91精品国产一区二区人妖| ww亚洲ww在线观看国产| 最新久久zyz资源站| 亚洲国产日产av| 国产一区二区三区免费看| 91蜜桃视频在线| 欧美一区在线视频| 亚洲欧洲日产国码二区| 日日摸夜夜添夜夜添国产精品| 岛国av在线一区| 欧美一区二区三区思思人| 久久久美女艺术照精彩视频福利播放| 一区二区在线观看视频在线观看| 久久精品久久综合| 色综合天天在线| 欧美成人性福生活免费看| 亚洲欧美激情一区二区| 狠狠久久亚洲欧美| 欧美日韩在线观看一区二区| 国产精品视频第一区| 麻豆一区二区99久久久久| 99在线精品视频| 精品黑人一区二区三区久久| 亚洲一级不卡视频| 国产91综合网| 欧美性猛交xxxx黑人交| 欧美三级日韩三级| 26uuu亚洲综合色欧美| 亚洲综合精品久久| 国产91丝袜在线播放| 日韩一卡二卡三卡| 亚洲国产视频直播| 91在线你懂得| 国产精品剧情在线亚洲| 国模少妇一区二区三区| 欧美一区二区三区爱爱| 亚洲一区免费在线观看| 99精品视频在线观看| 精品国产乱码久久久久久蜜臀| 国产69精品一区二区亚洲孕妇| 日韩欧美三级在线| 亚洲精品国产a久久久久久| 成人黄页毛片网站| 日韩免费视频一区| 午夜精品福利一区二区蜜股av| 99久久精品国产一区| 欧美国产一区二区在线观看| 黄一区二区三区| 欧美在线free| 亚洲国产美女搞黄色| 91原创在线视频| 亚洲精品美腿丝袜| 色婷婷综合久色| 中文字幕一区二区在线播放| 韩国av一区二区| 欧美va亚洲va国产综合| 青娱乐精品视频在线| 精品国产免费人成电影在线观看四季| 国产日本亚洲高清| 精品一区二区三区蜜桃| 欧美日韩一区二区三区高清| 国产精品久久久久久久裸模| 成人免费毛片片v| 国产性做久久久久久| 国产毛片一区二区| 91精品国产色综合久久不卡蜜臀| 亚洲国产精品一区二区www| 欧美最猛性xxxxx直播| 亚洲乱码精品一二三四区日韩在线| 狠狠v欧美v日韩v亚洲ⅴ| 日韩你懂的在线观看| 美日韩一级片在线观看| 日韩一区二区三区电影在线观看 | 国产精品亚洲专一区二区三区| 日韩三级高清在线| 捆绑调教一区二区三区| 欧洲人成人精品| 亚洲综合一区二区精品导航| 欧美一a一片一级一片| 日韩综合一区二区| 欧美日本乱大交xxxxx| 免费成人在线影院| 久久影视一区二区| 成人免费三级在线| 一片黄亚洲嫩模| 99re成人在线| 老司机免费视频一区二区| 欧美精品视频www在线观看| 夜夜嗨av一区二区三区中文字幕| 欧美久久久久久久久| 蜜桃久久久久久久| 国产偷国产偷亚洲高清人白洁| 成人免费观看视频| 一区二区三区在线免费播放| 欧美日韩国产综合视频在线观看 | 99re66热这里只有精品3直播 | 欧美一区二区三区四区视频| 国模一区二区三区白浆| 国产精品女同互慰在线看| 精品嫩草影院久久| 国产成人av影院| 亚洲精品免费播放| 欧美成人a在线| 中日韩av电影| 91精品国产综合久久久蜜臀图片| 蜜桃久久久久久| 国产精品第13页| 欧美丰满嫩嫩电影| 国产精品77777竹菊影视小说| 亚洲视频一二三| 日韩欧美电影一区| 99久久99精品久久久久久| 日韩高清国产一区在线| 久久精品亚洲麻豆av一区二区| 欧美在线一区二区| 国产主播一区二区三区| 一二三区精品视频| 久久精品人人爽人人爽| 欧美三区免费完整视频在线观看| 国产精品一区在线| 亚洲一区二区三区四区在线免费观看| 精品久久久久久久久久久久久久久| 91亚洲大成网污www| 日韩在线一区二区| 日韩码欧中文字| 日韩精品一区二区在线| 91麻豆成人久久精品二区三区| 久久黄色级2电影| 亚洲三级小视频| 久久综合九色综合久久久精品综合| youjizz久久| 免费成人美女在线观看| 亚洲欧洲性图库| 久久99九九99精品| 91精品国产福利| 91一区二区三区在线观看| 精品中文字幕一区二区| 亚洲已满18点击进入久久| 国产亚洲精品7777| 欧美一级日韩免费不卡| 在线欧美一区二区| 成人激情免费电影网址| 国内精品久久久久影院薰衣草 | 色国产精品一区在线观看| 精品一区二区三区在线播放视频| 亚洲一区二区美女| 1区2区3区国产精品| 国产色综合久久| 日韩欧美另类在线| 欧美日韩国产中文| 在线观看精品一区| a4yy欧美一区二区三区| 国产999精品久久| 国产一区亚洲一区| 久久 天天综合| 蜜臀91精品一区二区三区 | 欧美一区二区二区| 欧美日韩国产欧美日美国产精品| 一本到高清视频免费精品| 成人黄色小视频在线观看| 国产毛片一区二区| 黄网站免费久久| 韩日av一区二区| 狂野欧美性猛交blacked| 日本三级亚洲精品| 午夜影院久久久| 天堂va蜜桃一区二区三区漫画版| 一区二区三区不卡视频在线观看| 亚洲欧美日韩中文播放| 日韩理论电影院| 亚洲私人影院在线观看| 日韩美女精品在线| 亚洲日本乱码在线观看| 亚洲欧美日韩一区二区三区在线观看| |精品福利一区二区三区| 综合久久久久综合| 一区二区三区.www| 亚洲福利视频一区| 日韩在线观看一区二区| 免费久久99精品国产| 麻豆一区二区在线| 国产乱码精品一品二品| 国产99久久久久久免费看农村| 成人的网站免费观看| 日韩欧美中文一区| 丁香六月久久综合狠狠色|