程序员辅导:javaAES算法

来源:软件水平考试    发布时间:2012-11-05    软件水平考试视频    评论

  package com.rsa;
  import java.security.InvalidAlgorithmParameterException;
  import java.security.InvalidKeyException;
  import java.security.NoSuchAlgorithmException;
  import java.security.SecureRandom;
  import java.security.spec.AlgorithmParameterSpec;
  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.IvParameterSpec;
  public class AESEncrypter {
  public static byte[] iv = new byte[] { 82, 22, 50, 44, -16, 124, -40, -114, -87, -40, 37, 23, -56, 23, -33, 75 };
  private static AESEncrypter aes = null;
  public static byte[] key1 = new byte[] { -42, 35, 67, -86, 19, 29, -11, 84, 94, 111, 75, -104, 71, 46, 86, -21, -119, 110, -11, -32, -28, 91, -33, -46, 99, 49, 2, 66, -101, -11, -8, 56 };
  private AESEncrypter() {
  }
  public static synchronized AESEncrypter getInstance() {
  if (aes == null) {
  aes = new AESEncrypter();
  }
  return aes;
  }
  public String encrypt(String msg) {
  String str = "";
  try {
  KeyGenerator kgen = KeyGenerator.getInstance("AES");
  kgen.init(128, new SecureRandom(key1));
  AlgorithmParameterSpec paramSpec = new IvParameterSpec(iv);
  SecretKey key = kgen.generateKey();
  Cipher ecipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
  ecipher.init(Cipher.ENCRYPT_MODE, key, paramSpec);
  str = asHex(ecipher.doFinal(msg.getBytes()));
  } catch (BadPaddingException e) {
  e.printStackTrace();
  } catch (NoSuchAlgorithmException e) {
  e.printStackTrace();
  } catch (NoSuchPaddingException e) {
  e.printStackTrace();

上一页12下一页

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答