ホームページ  >  記事  >  Java  >  AES暗号化を実装するにはどうすればよいですか?

AES暗号化を実装するにはどうすればよいですか?

PHP中文网
PHP中文网オリジナル
2017-06-20 14:48:081492ブラウズ

package util;

import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import javax.crypto.BadPaddingException;
import javax.crypto .Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.apache .tomcat.util.codec.binary.Base64;

/**
*
* @著者管理者
*
*/
public class AES {

// 加密
public static String Encrypt(String sSrc, String sKey) throws Exception {
if (sKey) == null) {
System.out.print("Key は空null");
return null;
}
// 判断Keyが16位かどうか
if (sKey.length() != 16)システム.out.print("Key长度不是16位");
return null;
}
byte[] raw = sKey.getBytes("utf-8");
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES") ;
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");//"算法/模式/补码方式"
cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] encrypted = cipher.doFinal (sSrc.getBytes("utf-8"));

return new Base64().encodeToString(encrypted);//ここでは BASE64 を使用して暗号化機能を実行し、同時に 2 回の加密効果を引き起こします。

// 復号化
public static String Decrypt(String sSrc, String sKey) throws Exception {
System.out.print("Key is empty null ");
Return NULL
}
// キーが 16 であるかどうかを判断します。 bit
iF (SKEY.Length ()! = 16) {
System.out.print (" キーは 16 ビットではありません ");
}
byte[] raw = sKey.getBytes("utf-8") ;
getInstance ("AES/ECB/PKCS5Padding) ") ;
cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] encrypted1 = new Base64().decode(sSrc);//最初に復号化するにはbase64を使用します
byte [] Original = cipher.doFinal(encrypted1) ; In String Originalstring = New String (Original, "UTF-8");
Catch (Exception E) {
System.oT.println ( )); N を返します
}
} Catch (例外 EX) {
System.out.println (ex.tostring ());
テスト、文字列パスワード) {
.getBytes()));
SecretKey SecretKey = kgen.generateKey(); byte[ ] ENCODEFORMAT = Secretkey.Getencoded ();
Secretkeyspec Key = New Secretkeyspec (EncodeFormat, "AES");スタンス ("AES" ); // を作成します。パスワード
byte [] bytecontent = Content.getbytes ("UTF-8");
cipher.init (cipher.encrypt_mode, key); //
byte [] result = cipher.dofinal (bytecontent);
e.printStackTrace(); e) {
e.printStackTrace(); } BlockSizeException e) {
                   e.printStackTrace();  
} catch (BadPaddingException e) {
e.printStackTrace();  
}
null を返します。  
}
/**復号化
* @param content 復号化するコンテンツ
* @param パスワード 復号化キー
* @return
*/
public static byte[] decrypt(byte[] content, String password) {
try {
KeyGenerator kgen = KeyGenerator.getInstance(" AES");  
kgen.init(128, new SecureRandom(password.getBytes()));  
SecretKey SecretKey = kgen.generateKey();  
byte[] enCodeFormat = SecretKey.getEncoded();  
SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");              
Cipher cipher = Cipher.getInstance("AES");// 创建暗号器
cipher.init(Cipher.DECRYPT_MODE, key);// 初期化
byte[] result = cipher.doFinal(content);  
結果を返します。 // 加密
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();  
} catch (NoSuchPaddingException e) {
e.printStackTrace();  
} catch (InvalidKeyException e) {
e.printStackTrace();  
} catch (IllegalBlockSizeException e) {
e.printStackTrace();  
} catch (BadPaddingException e) {
e.printStackTrace();  
}
null を返します。  
}
/**2 進数を 16 進数に変換します
* @param buf
* @return
*/
public static String parseByte2HexStr(byte buf[]) {
StringBuffer sb = new StringBuffer();  
for (int i = 0; i String hex = Integer.toHexString(buf[i] & 0xFF);  
if (hex.length() == 1) {
hex = '0' + hex;  
}
sb.append(hex.toUpperCase());  
}
return sb.toString();  
}}/ **&#&*/
public static byte [] parsehexstr2byte(string hexstr){
if(hexstr.length()< 1)
return null;  
byte[] result = new byte[hexStr.length()/2];  
for (int i = 0;i< hexStr.length()/2; i++) {
int high = Integer.parseInt(hexStr.substring(i*2, i*2+1), 16);
int low = Integer.parseInt(hexStr.substring(i*2+1, i*2+2), ( String[] args) throws Exception {
/*
* ここ AES-128-ECB 暗号化モードを使用する場合、キーは 16 ビットである必要があります。 T */r String CKEY = "1234567890123456";
// 暗号化された文字列
String CSRC = "www.gowhere.so";
System.out.println (CSRC); .out.println("暗号化された文字列は次のとおりです: " + enString);

// 復号化します
String DeString = AES.Decrypt(enString, cKey);
System.out .println("復号化された文字列は次のとおりです: " + DeString );
文字列の内容 = "test"; ‐ ‐‐‐‐‐ content = ="テスト" );
byte[] encryptResult = encrypt(コンテンツ, パスワード);
String encryptResultStr = parseByte2HexStr(encryptResult);
System.out.println("暗号化後: " + encryptResultStr); );
System.out.println("復号化後: " + new String(decryptResult));

以上がAES暗号化を実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。