2014-06-11 9 views
0

다른 프로그램의 암호를 저장하는 데 동일한 MySQL 테이블을 사용하고 있습니다. 하나는 Java로 작성되고 다른 하나는 PHP로 작성됩니다.MD5와 소금을 사용하여 Java에서 암호 암호화

나는이 스크립트를 사용하여 PHP를 통해 비밀번호를 저장하고 :

encrypted_password= md5(md5('added_salt').md5(md5('plain_password'))); 

나는 위와 같이 MD5와 소금을 사용하여 Java에서 암호를 암호화해야합니다. 나는 자바 코드를 작성하지만 출력이 다릅니다입니다 :

 MessageDigest md = MessageDigest.getInstance("MD5"); 


     String salts = "a,d,d,e,d,_,s,a,l,t"; 

     String salttmps[] = salts.split(","); 
     byte salt[] = new byte[salttmps.length]; 

     for (int i = 0; i < salt.length; i++) { 
      salt[i] = Byte.parseByte(salttmps[i]); 
     } 
     md.update(salt); 
     md.update(password.getBytes()); 

     byte byteData[] = md.digest(); 


     StringBuffer sb = new StringBuffer(); 
     for (int i = 0; i < byteData.length; i++) { 
     sb.append(Integer.toString((byteData[i] & 0xff) + 0x100, 16).substring(1)); 
     } 
     password = sb.toString(); 

내가 자바 코드를 수정하고 PHP와 같은 출력을 생성해야합니다.

+2

(http://stackoverflow.com/questions/401656/ :

난 당신이 뭔가를해야 할 것 같아요 secure-hash-and-salt-for-ph-passwords) – kero

+0

다른 옵션이 있습니까? 이미 MD5를 사용하는 PHP 응용 프로그램이 있습니다. –

+0

http://stackoverflow.com/questions/4183646/java-md5-the-php-way – cy3er

답변

1

질문에 출력 예를 게시 할 수 있다면 알고리즘을 재현하는 것이 좋습니다.

public static void main(String[] args) { 

    try { 
     System.out.println(md5(md5("added_salt"), md5("plain_password"))); 
    } catch (NoSuchAlgorithmException e) { 
     e.printStackTrace(); 
    } 
} 

public static String md5(String plainText) throws NoSuchAlgorithmException { 
    return md5(null, plainText); 
} 

public static String md5(String salt, String plainText) 
     throws NoSuchAlgorithmException { 
    MessageDigest md = MessageDigest.getInstance("MD5"); 

    if (salt != null) { 
     md.update(salt.getBytes()); 
    } 
    md.update(plainText.getBytes()); 

    byte byteData[] = md.digest(); 

    StringBuffer sb = new StringBuffer(); 
    for (int i = 0; i < byteData.length; i++) { 
     sb.append(Integer.toString((byteData[i] & 0xff) + 0x100, 16) 
       .substring(1)); 
    } 
    return sb.toString(); 
} 

md5(md5("added_salt"), md5("plain_password")) 반환 당신은 정말 [`md5` 사용해서는 안]을 3bd9e544ab1a3d3485f07af38cc1b415

+0

잘 작동합니다. 고맙습니다. –