Java와 Node.js가 AES 암호화를 이용하여 같은 결과를 복호화하는 방법의 예

앞말
작업 중 nodejs단이 aes를 통해 암호화되고 안드로이드 클라이언트 자바가 복호화되는 것을 만났습니다. 마찬가지로 nodejs도 안드로이드 클라이언트가 암호화한 내용을 복호화해야 합니다. 두 개의 암호화 결과가 다르다는 것을 발견했습니다. 조회 자료에 의하면 자바단은 키를 다시 MD5로 암호화해야 합니다. 다음은 자바와 노드입니다.js는 AES 암호화를 이용하여 같은 결과를 복호화하는 방법입니다. 필요한 분들은 다음에 같이 공부하세요.
JAVA 코드는 다음과 같습니다.

package g.g;

import java.security.MessageDigest;

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class AesECB {
 public static final String DEFAULT_CODING = "utf-8"; 
  
 /** 
  *   
  * @author lmiky 
  * @date 2014-2-25 
  * @param encrypted 
  * @param seed 
  * @return 
  * @throws Exception 
  */ 
 private static String decrypt(String encrypted, String seed) throws Exception { 
  byte[] keyb = seed.getBytes(DEFAULT_CODING); 
  MessageDigest md = MessageDigest.getInstance("MD5"); 
  byte[] thedigest = md.digest(keyb); 
  SecretKeySpec skey = new SecretKeySpec(thedigest, "AES"); 
  Cipher dcipher = Cipher.getInstance("AES"); 
  dcipher.init(Cipher.DECRYPT_MODE, skey); 
 
  byte[] clearbyte = dcipher.doFinal(toByte(encrypted)); 
  return new String(clearbyte); 
 } 
 
 /** 
  *   
  * @author lmiky 
  * @date 2014-2-25 
  * @param content 
  * @param key 
  * @return 
  * @throws Exception 
  */ 
 public static String encrypt(String content, String key) throws Exception { 
  byte[] input = content.getBytes(DEFAULT_CODING); 
   
  MessageDigest md = MessageDigest.getInstance("MD5"); 
  byte[] thedigest = md.digest(key.getBytes(DEFAULT_CODING)); 
  SecretKeySpec skc = new SecretKeySpec(thedigest, "AES"); 
  Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding"); 
  cipher.init(Cipher.ENCRYPT_MODE, skc); 
   
  byte[] cipherText = new byte[cipher.getOutputSize(input.length)]; 
  int ctLength = cipher.update(input, 0, input.length, cipherText, 0); 
  ctLength += cipher.doFinal(cipherText, ctLength); 
    
  return parseByte2HexStr(cipherText); 
 } 
  
 /** 
  *   
  * @author lmiky 
  * @date 2014-2-25 
  * @param hexString 
  * @return 
  */ 
 private static byte[] toByte(String hexString) { 
  int len = hexString.length() / 2; 
  byte[] result = new byte[len]; 
  for (int i = 0; i < len; i++) { 
   result[i] = Integer.valueOf(hexString.substring(2 * i, 2 * i + 2), 16).byteValue(); 
  } 
  return result; 
 } 
  
 /** 
  *  16  
  * @author lmiky 
  * @date 2014-2-25 
  * @param buf 
  * @return 
  */ 
 private static String parseByte2HexStr(byte buf[]) { 
  StringBuffer sb = new StringBuffer(); 
  for (int i = 0; i < buf.length; i++) { 
   String hex = Integer.toHexString(buf[i] & 0xFF); 
   if (hex.length() == 1) { 
    hex = '0' + hex; 
   } 
   sb.append(hex); 
  } 
  return sb.toString(); 
 } 
  
 public static void main(String[] args) throws Exception { 
  System.out.println(AesECB.encrypt("fsadfsdafsdafsdafsadfsadfsadf", "1eVRiqy7b9Uv7ZMM")); 
  System.out.println(AesECB.decrypt("b123e2d9199598c0e3f1999dc9e723387b68e29d2b3a0d59fc7d5946c750c6b4", "1eVRiqy7b9Uv7ZMM")); 
 }
}
Node.js 코드는 다음과 같습니다.

var crypto = require('crypto');
exports.aes_algorithm = "aes-128-ecb";
exports.aes_secrect = "1eVRiqy7b9Uv7ZMM";

exports.encrypt = function (text) {
 var cipher = crypto.createCipher(this.aes_algorithm, this.aes_secrect)
 var crypted = cipher.update(text, 'utf8', 'hex')
 crypted += cipher.final('hex');
 return crypted;
};

exports.decrypt = function (text) {
 var decipher = crypto.createDecipher(this.aes_algorithm, this.aes_secrect)
 var dec = decipher.update(text, 'hex', 'utf8')
 dec += decipher.final('utf8');
 return dec;
};

//var hw = this.encrypt("fsadfsdafsdafsdafsadfsadfsadf");
//console.log(hw);
//console.log(this.decrypt(hw));
총결산
이상은 바로 이 글의 전체 내용입니다. 본고의 내용이 여러분의 학습이나 업무에 일정한 도움을 줄 수 있기를 바랍니다. 만약에 의문이 있으면 여러분은 댓글을 남겨 교류할 수 있습니다. 저희에 대한 지지에 감사드립니다.

좋은 웹페이지 즐겨찾기