2012-04-17 35 views
0
import java.security.Key; 
    import java.security.MessageDigest; 
    import java.security.NoSuchAlgorithmException; 
    import java.security.SecureRandom; 
    import java.security.Security; 
    import java.util.Arrays; 
    import javax.crypto.Cipher; 
    import javax.crypto.KeyGenerator; 
    import javax.crypto.SecretKey; 
    import javax.crypto.spec.IvParameterSpec; 
    import javax.crypto.spec.SecretKeySpec; 
    import java.security.MessageDigest; 

public class SHAhashingexample 
    { 
     public static void main(String[] args)throws Exception 
     { 
      Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider()); 
      String usernametohash = "123456"; 
      String salt="salty food"; 
      String userdata="hello how are you!"; 
      MessageDigest md = MessageDigest.getInstance("SHA-256"); 
      md.update((usernametohash+salt).getBytes()); 
      byte byteData[] = md.digest(); 
      System.out.println("Digested value : " + byteData); 
      StringBuffer sb = new StringBuffer(); 
      for (int i = 0; i < byteData.length; i++) 
      { 
      sb.append(Integer.toString((byteData[i] & 0xff) + 0x100, 16).substring(1)); 
      } 
      System.out.println("Hash code value of username : " + sb); 
       byte[] actualkey=sb.toString().getBytes(); 
      byte[] first_key = Arrays.copyOf(actualkey, 16); 
      Key key = new SecretKeySpec(first_key, "AES"); 
      System.out.println("Derived AES key is "+key.toString()); 
      SecureRandom random = new SecureRandom(); 
      IvParameterSpec ivSpec = createCtrIvForAES(1, random); 
      Cipher cipher = Cipher.getInstance("AES/CTR/NoPadding", "BC"); 
      cipher.init(Cipher.ENCRYPT_MODE, key, ivSpec); 
      byte[] cipherText = cipher.doFinal(userdata.getBytes()); 
      System.out.println("ciphertext is : " + cipherText); 
      cipher.init(Cipher.DECRYPT_MODE, key, ivSpec); 
      byte[] plainText = cipher.doFinal(cipherText) ; 
      System.out.println("plaintext is : " + plainText); 

      } 

     public static IvParameterSpec createCtrIvForAES(int messageNumber, SecureRandom random) 
     { 
      byte[] ivBytes = new byte[16]; 
      random.nextBytes(ivBytes); 
      for (int i = 0; i < 16; i++) 
      { 
       ivBytes[i] = 0; 
      } 
      return new IvParameterSpec(ivBytes); 
      } 
    } 

我的意圖是從用戶名散列和硬編碼隨機數派生出128位密鑰,採用算法SHA-256和AES CTR模式。想要生成用戶名散列使用SHA-256算法。我覺得我們需要IV與CTR模式一起使用,初始化向量的值應該是什麼,我只是猜測它們全部爲零...當我解密時,我沒有得到正確的明文

+1

首先讓它成爲一個更簡單的問題。如果你不做你想要的密鑰生成,你的加密/解密是否對稱? – 2012-04-17 04:37:46

+0

我可以知道初始化向量的使用以及何時以及如何使用它......我實際上在網上覆制了一些程序,並對其進行了修改並如上所述。 – 2012-04-17 07:34:27

回答

1

你在這裏做了很多錯誤的事情,但您的實際問題是您忘記使用new String(plainText)從返回的值重新創建字符串。

一切都達到幷包括密鑰推導也不好。嘗試使用PBKDF2找到一些Java樣本(本網站應該有很多),並嘗試理解Java中的(字符)編碼。

相關問題