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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? encryption.java~138~

?? 用JAVA編寫的用密碼學中DES算法加密解密文件的程序
?? JAVA~138~
?? 第 1 頁 / 共 2 頁
字號:
    for(int i=0; i<16; i++)    {      passIP+=textInBi.charAt(IP[i]-1);    }    System.out.println("****************************passIP is "+passIP);    g1=passIP.substring(0,8);    g2=passIP.substring(8,16);    //first pass F and combine    passF=functionF(g1,subkey1);    System.out.println("**********************pass function F1 is "+passF);    passCombine1=combine(passF,g2);    System.out.println("*************************passCombine1 is "+passCombine1);    //second pass F and combine    passF=functionF(passCombine1,subkey2);    System.out.println("****************************pass function F2 is "+passF);    passCombine2=combine(passF,g1);    System.out.println("******************************passCombine2 is "+passCombine2);    //concate two subString with 8 bits    beforeIP_1=passCombine1+passCombine2;    System.out.println("the length of before IP-1 is "+beforeIP_1.length());    for(int i=0; i<16; i++)    {      passIP_1+=beforeIP_1.charAt(IP_1[i]-1);    }    System.out.println("passIP_1 is"+passIP_1);    subEncry=biToText(passIP_1);    return subEncry;  }  public String biToText(String bi)  {    String text="";    String subBi="";    int biToD=0;    System.out.println("bi is "+bi+" the length is "+bi.length());    for(int i=0; i<bi.length();i++)    {      subBi=bi.substring(i,i+8);      System.out.println("subString "+i+" is "+subBi);      i+=7;      biToD=Integer.parseInt(convertBToD(subBi));      System.out.println("decimal "+i+" is"+biToD);      text+=(char)biToD;      System.out.println("subtext is "+text);    }    return text;  }  public String textToBi(String subText)  {    String bi="";    String sub1="";    String sub2="";    int c1=subText.charAt(0);    int c2=subText.charAt(1);    sub1=convertDToB(c1,8);    System.out.println("sub1 is "+sub1);    sub2=convertDToB(c2,8);    bi=sub1+sub2;    System.out.println("&&&&&&&&&&&&&&&&&&&&&&&key is "+bi);    return bi;  }  public String functionF(String R, String subkey)  {    String E="812345456781";    String P="64735182";    String passE="";    String passCombine="";    String passSBox1="";    String passSBox2="";    String passSBox="";    String passP="";    //R pass E    for(int i=0; i<12; i++)    {      passE+=R.charAt(Integer.parseInt(E.substring(i,i+1))-1);    }    //E pass combination    passCombine+=combine(passE, subkey);    //get two substirng with 6 digits    String beforeSBox1=passCombine.substring(0,6);    String beforeSBox2=passCombine.substring(6,12);    //get two substring with 4 digits    passSBox1=passSBox(1,beforeSBox1);    passSBox2=passSBox(2,beforeSBox2);    //print out combine    System.out.println("box1 is ");    for(int i=0; i<passSBox1.length();i++)    {      System.out.print(passSBox1.charAt(i));    }    //print out combine    System.out.println("SBox2 is ");    for(int i=0; i<passSBox2.length();i++)    {      System.out.print(passSBox2.charAt(i));    }    //concate two substring into one    passSBox=passSBox1+passSBox2;    //pass P    for(int i=0; i<passSBox.length(); i++)    {      passP+=passSBox.charAt(Integer.parseInt(P.substring(i,i+1))-1);    }    return passP;  }  public String combine(String G1, String G2)  {    String combine="";    if(G1.length()==G2.length())    {      for(int i=0; i<G1.length(); i++)      {        combine+=XOR(G1.charAt(i),G2.charAt(i));      }    }    return combine;  }  public char XOR(char a, char b)  {    char c;    if(a==b)        c='0';    else        c='1';    return c;  }  //subString with 6 bits to pass box to get a string with 4 digits  public String passSBox(int box, String beforeBox)  {    String afterBox="";    //get row number in binary    String row=beforeBox.substring(0,1);    row+=beforeBox.charAt(5);    //get colum number in binary    String colum="";    for(int i=1; i<=4;i++)    {      colum+=beforeBox.charAt(i);    }    //convert binary to decimal to get row and colum in s-box    String inBoxRow=convertBToD(row);    String inBoxColum=convertBToD(colum);    int iRow=Integer.parseInt(inBoxRow);    int iColum=Integer.parseInt(inBoxColum);    afterBox=inSBox(box,iRow,iColum);    return afterBox;  }  //convert binary to decimal  public String convertBToD(String a)  {    int ctr=1, decimal=0;    for (int i = a.length()-1; i>=0; i--)    {      if(a.charAt(i)=='1')        decimal+=ctr;      ctr*=2;    }    String converted = "" + decimal;    return converted;  }  //find the number in S-Box  public String inSBox(int box, int row, int colum)  {    int boxNum=0;    String bin;    int[][] SBox1=    {      {14, 4, 13,  1,  2, 15, 11,  8,  3, 10,  6, 12,  5,  9,  0,  7},      {0, 15,  7,  4, 14,  2, 13,  1, 10,  6, 12, 11,  9,  5,  3,  8},      {4,  1, 14,  8, 13,  6,  2, 11, 15, 12,  9,  7,  3, 10,  5,  0},      {15, 12, 8,  2,  4,  9,  1,  7,  5, 11,  3, 14, 10,  0,  6, 13},    };    int[][] SBox2=    {      {15, 1,  8, 14,  6, 11,  3,  4,  9,  7,  2, 13, 12,  0,  5, 10},      {3, 13,  4,  7, 15,  2,  8, 14, 12,  0,  1, 10,  6,  9, 11,  5},      {0, 14,  7, 11, 10,  4, 13,  1,  5,  8, 12,  6,  9,  3,  2, 15},      {13,  8, 10,  1,  3, 15,  4,  2, 11,  6,  7, 12,  0,  5, 14, 9},    };    if(box==1)      boxNum=SBox1[row][colum];    if(box==2)      boxNum=SBox2[row][colum];    //get binary with 4 digits in string from s-box    bin=convertDToB(boxNum,4);    return bin;  }  //convert decimal number into binary in String  public String convertDToB (int deci,int bits)  {    String bi="";    //convert decimal into binary    while (deci>=1)    {      if(deci%2==0)        bi+="0";      if(deci%2==1)        bi+="1";      deci/=2;    }    if(bits==4)    {      //let String bi has four digits      while (bi.length() != 4)      {        bi += "0";      }    }    if(bits==8)     {       //let String bi has four digits       while (bi.length() != 8)       {         bi += "0";       }     }    bi=inverse(bi);    return bi;  }//inverse binary order  public String inverse(String oldS)  {    String newS="";    for(int i=oldS.length()-1; i>=0; i--)    {      newS+=oldS.charAt(i);    }    return newS;  }  //calculate two subkeys  public  String[] calSubKey(String Key) {   String[] subKey = new String[2];  //PC1 condition  int[] PC1 = {11,15,4,13,7,9,3,               2,5,14,6,10,12,1};  int[] PC2 = {6,11,4,8,13,3,               12,5,1,10,2,9};  //the key After PC1  String passKey1= "";  //the subKey1 and subKey2  String subKey1 = "";  String subKey2 = "";  //the result of key after PC1  for(int i=0;i<PC1.length;i++)  {    passKey1 += Key.charAt(PC1[i]-1);  }  //Divide the result into left bits(cKey) and right bits(dKey)  String cKey = passKey1.substring(0,7);  String dKey = passKey1.substring(7);  //Calculate subKey1-------------------------------  //Shift to the right at 2 positions for both c and d  String c1Key = cKey.substring(5)+cKey.substring(0,5);  String d1Key = dKey.substring(5)+dKey.substring(0,5);  //combine c1 and d1  String tempKey1 = "";  tempKey1 = c1Key + d1Key;  //after PC2,get K1  for(int i=0;i<PC2.length;i++)  {    subKey1+=tempKey1.charAt(PC2[i]-1);  }  //Calculate subKey2----------------------------------  //Shift to the right at 2 positions for both c1 and d1  String c2Key = c1Key.substring(5)+c1Key.substring(0,5);  String d2Key = d1Key.substring(5)+d1Key.substring(0,5);  //combine c2 and d2  String tempKey2 = "";  tempKey2 = c2Key + d2Key;  //pass PC2 , get k2  for(int i=0;i<PC2.length;i++)  {    subKey2+=tempKey2.charAt(PC2[i]-1);  }  subKey[0] = subKey1;  subKey[1] = subKey2;  return subKey; }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频一二| 成人福利视频在线看| 成人国产精品免费网站| 欧美性videosxxxxx| 日韩精品一区二区三区在线| 亚洲视频 欧洲视频| 久久国产精品第一页| 欧美性色综合网| 国产精品午夜免费| 蜜臀av国产精品久久久久| 91官网在线观看| 国产精品福利电影一区二区三区四区 | 国产在线精品视频| 欧美精品丝袜久久久中文字幕| 国产精品久久午夜| 国产一区在线观看视频| 欧美一级片在线观看| 亚洲资源中文字幕| 色婷婷综合久久久| 日韩一区日韩二区| 丁香天五香天堂综合| 久久婷婷色综合| 蜜臀av在线播放一区二区三区| 欧美无乱码久久久免费午夜一区| 中文字幕人成不卡一区| 国产精品一区二区三区网站| 欧美哺乳videos| 秋霞av亚洲一区二区三| 欧美精品1区2区| 亚洲电影在线免费观看| 欧美日韩你懂得| 亚洲成人动漫一区| 欧美影院精品一区| 亚洲综合久久久| 欧美日韩不卡在线| 午夜精品视频一区| 欧美日本韩国一区二区三区视频| 亚洲成人资源网| 91精品国产91久久综合桃花| 奇米精品一区二区三区四区 | 26uuu成人网一区二区三区| 另类小说色综合网站| 久久先锋影音av鲁色资源网| 国产毛片精品视频| 国产精品美女久久久久aⅴ| 成人伦理片在线| 亚洲精品免费在线播放| 欧美视频中文字幕| 免费欧美在线视频| 久久精子c满五个校花| 国产91精品免费| 最近日韩中文字幕| 在线播放视频一区| 国产精品18久久久久久久网站| 中文子幕无线码一区tr| 在线亚洲一区二区| 麻豆成人91精品二区三区| 久久久久久久久久美女| 91原创在线视频| 三级成人在线视频| 国产欧美日韩在线视频| 欧美写真视频网站| 国产精品综合一区二区三区| 亚洲精品写真福利| 精品免费国产二区三区| 色素色在线综合| 精品一区二区三区久久久| 中文字幕日韩一区二区| 欧美一区二区三区不卡| 国产成人在线免费| 三级欧美在线一区| 国产精品国产三级国产aⅴ中文| 欧美伊人久久久久久午夜久久久久| 免费在线观看成人| 亚洲人xxxx| 久久综合久久综合久久| 欧美视频在线观看一区二区| 国产白丝网站精品污在线入口| 亚洲国产视频一区| 亚洲欧洲日产国码二区| 日韩欧美国产综合| 欧美丝袜自拍制服另类| 国产成人av一区二区三区在线| 亚洲一二三区在线观看| 国产日产精品1区| 欧美精品色一区二区三区| 懂色中文一区二区在线播放| 日本欧美一区二区三区乱码| 亚洲视频网在线直播| 国产欧美一区二区精品仙草咪| 69av一区二区三区| 在线视频欧美精品| 成人h版在线观看| 国内外成人在线视频| 精品制服美女久久| 午夜精品福利视频网站| 亚洲卡通欧美制服中文| 国产视频一区在线观看| 精品免费国产二区三区| 日韩西西人体444www| 欧美日韩一区精品| 日本道色综合久久| 91福利在线播放| 91麻豆精品一区二区三区| 风流少妇一区二区| 国产91精品入口| 国产不卡一区视频| 国产经典欧美精品| 国产高清精品网站| 国产老女人精品毛片久久| 国产精品18久久久久久久网站| 久久91精品国产91久久小草| 美国精品在线观看| 韩国v欧美v日本v亚洲v| 国产成人自拍网| 国产传媒欧美日韩成人| 风间由美一区二区三区在线观看 | 91一区二区在线| 99麻豆久久久国产精品免费| 福利电影一区二区| 9人人澡人人爽人人精品| 99精品国产一区二区三区不卡| 成人av动漫网站| 色综合天天综合给合国产| 在线亚洲免费视频| 欧美精品欧美精品系列| 日韩欧美亚洲国产精品字幕久久久 | 在线观看成人免费视频| 欧美日韩精品欧美日韩精品一综合| 欧美在线高清视频| 欧美一级日韩一级| 国产欧美日韩视频在线观看| 国产精品久久久久久久久果冻传媒 | 久久久久久久久久美女| 国产精品欧美极品| 亚洲自拍偷拍图区| 激情文学综合插| 99久久免费国产| 欧美乱熟臀69xxxxxx| 精品国产乱码久久久久久老虎 | 精品国产露脸精彩对白| 国产欧美va欧美不卡在线| 亚洲精品乱码久久久久久久久 | 91在线观看视频| 欧美色电影在线| 2020国产成人综合网| 综合av第一页| 日本欧美大码aⅴ在线播放| 国产精品亚洲一区二区三区妖精| 99riav久久精品riav| 91精品国产综合久久精品麻豆 | 欧美精品 国产精品| 亚洲精品在线免费观看视频| 亚洲乱码国产乱码精品精可以看| 天天色综合天天| 成人av免费在线播放| 欧美一级艳片视频免费观看| 国产精品久久久久久久岛一牛影视| 亚洲一二三专区| 成人天堂资源www在线| 这里只有精品视频在线观看| 国产精品麻豆久久久| 麻豆一区二区99久久久久| 99re66热这里只有精品3直播| 日韩免费一区二区| 亚洲一区二区三区四区五区黄| 国产一区视频网站| 91麻豆精品国产91久久久更新时间| 国产精品国产精品国产专区不蜜| 青娱乐精品视频| 99国产精品久久久久久久久久| 337p日本欧洲亚洲大胆精品| 亚洲成人动漫在线免费观看| 99久久精品国产一区| 国产亚洲一二三区| 免费成人在线观看| 欧美欧美欧美欧美首页| 日韩美女视频一区| 成人一区二区视频| 久久综合精品国产一区二区三区| 午夜日韩在线观看| 欧美在线综合视频| 中文字幕一区二区三区精华液| 极品美女销魂一区二区三区免费| 欧美群妇大交群中文字幕| 亚洲免费看黄网站| www.性欧美| 欧美国产激情一区二区三区蜜月| 激情综合网激情| 日韩欧美国产一区在线观看| 男女性色大片免费观看一区二区| 91福利视频久久久久| 一区二区久久久| 色综合欧美在线| 亚洲欧美影音先锋| 99精品欧美一区| 一区二区三区日韩欧美| 欧美在线播放高清精品| 亚洲一二三四久久| 欧美日韩国产一级|