首頁 >Java >java教程 >java實作RC4加密解密的實例教程

java實作RC4加密解密的實例教程

零下一度
零下一度原創
2017-06-17 11:32:492143瀏覽

這篇文章主要介紹了java實現的RC4加密解密演算法,結合具體實例形式分析了java RC4加密解密演算法的實現與使用技巧,需要的朋友可以參考下

本文實例講述了java實作的RC4加密解密演算法。分享給大家供大家參考,具體如下:

有一個項目,需要解析一個用戶提供的rc4加密後的文件,特意搜尋整理了一個Java 版本的RC4加解密演算法。


public static String HloveyRC4(String aInput,String aKey)
{
    int[] iS = new int[256];
    byte[] iK = new byte[256];
    for (int i=0;i<256;i++)
      iS[i]=i;
    int j = 1;
    for (short i= 0;i<256;i++)
    {
      iK[i]=(byte)aKey.charAt((i % aKey.length()));
    }
    j=0;
    for (int i=0;i<255;i++)
    {
      j=(j+iS[i]+iK[i]) % 256;
      int temp = iS[i];
      iS[i]=iS[j];
      iS[j]=temp;
    }
    int i=0;
    j=0;
    char[] iInputChar = aInput.toCharArray();
    char[] iOutputChar = new char[iInputChar.length];
    for(short x = 0;x<iInputChar.length;x++)
    {
      i = (i+1) % 256;
      j = (j+iS[i]) % 256;
      int temp = iS[i];
      iS[i]=iS[j];
      iS[j]=temp;
      int t = (iS[i]+(iS[j] % 256)) % 256;
      int iY = iS[t];
      char iCY = (char)iY;
      iOutputChar[x] =(char)( iInputChar[x] ^ iCY) ;
    }
    return new String(iOutputChar);
}

加密和解密都用這一個方法。也就是說參數String aInput 可以傳一個明文,也可以傳送一個加密後的字串,程式會自動的辨識。然後執行加解密的響應操作。

使用範例如下:


public static void main(String[] args) {
  String inputStr = "做个好男人";
  String key = "abcdefg";
  String str = HloveyRC4(inputStr,key);
  //打印加密后的字符串
  System.out.println(str);
  //打印解密后的字符串
  System.out.println(HloveyRC4(str,key));
}

以上是java實作RC4加密解密的實例教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn