首頁 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實用文檔 求職招聘 論文下載
2011中考 | 2011高考 | 2012考研 | 考研培訓(xùn) | 在職研 | 自學(xué)考試 | 成人高考 | 法律碩士 | MBA考試
MPA考試 | 中科院
四六級 | 職稱英語 | 商務(wù)英語 | 公共英語 | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT
新概念英語 | 成人英語三級 | 申碩英語 | 攻碩英語 | 職稱日語 | 日語學(xué)習(xí) | 法語 | 德語 | 韓語
計算機等級考試 | 軟件水平考試 | 職稱計算機 | 微軟認證 | 思科認證 | Oracle認證 | Linux認證
華為認證 | Java認證
公務(wù)員 | 報關(guān)員 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 期貨從業(yè)資格 | 司法考試 | 法律顧問 | 導(dǎo)游資格
報檢員 | 教師資格 | 社會工作者 | 外銷員 | 國際商務(wù)師 | 跟單員 | 單證員 | 物流師 | 價格鑒證師
人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業(yè)資格 | 廣告師職業(yè)水平
駕駛員 | 網(wǎng)絡(luò)編輯
衛(wèi)生資格 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 執(zhí)業(yè)護士
會計從業(yè)資格考試會計證) | 經(jīng)濟師 | 會計職稱 | 注冊會計師 | 審計師 | 注冊稅務(wù)師
注冊資產(chǎn)評估師 | 高級會計師 | ACCA | 統(tǒng)計師 | 精算師 | 理財規(guī)劃師 | 國際內(nèi)審師
一級建造師 | 二級建造師 | 造價工程師 | 造價員 | 咨詢工程師 | 監(jiān)理工程師 | 安全工程師
質(zhì)量工程師 | 物業(yè)管理師 | 招標師 | 結(jié)構(gòu)工程師 | 建筑師 | 房地產(chǎn)估價師 | 土地估價師 | 巖土師
設(shè)備監(jiān)理師 | 房地產(chǎn)經(jīng)紀人 | 投資項目管理師 | 土地登記代理人 | 環(huán)境影響評價師 | 環(huán)保工程師
城市規(guī)劃師 | 公路監(jiān)理師 | 公路造價師 | 安全評價師 | 電氣工程師 | 注冊測繪師 | 注冊計量師
繽紛校園 | 實用文檔 | 英語學(xué)習(xí) | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲
您現(xiàn)在的位置: 考試吧(Exam8.com) > 軟件水平考試 > 復(fù)習(xí)資料 > 程序員資料 > 正文

2010計算機軟考程序員輔導(dǎo)資料《javaAES算法》

考試吧整理了程序員輔導(dǎo):javaAES算法,幫助考生備考程序員考試。

  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(); } catch (InvalidKeyException e) {

  e.printStackTrace();} catch (InvalidAlgorithmParameterException e) {e.printStackTrace();} catch (IllegalBlockSizeException e) {e.printStackTrace();}

  return str;}

  public String decrypt(String value) {try {

  KeyGenerator kgen = KeyGenerator.getInstance("AES");

  kgen.init(128, new SecureRandom(key1));

  AlgorithmParameterSpec paramSpec = new IvParameterSpec(iv);

  SecretKey key = kgen.generateKey();

  Cipher dcipher = Cipher.getInstance("AES/CBC/PKCS5Padding");

  dcipher.init(Cipher.DECRYPT_MODE, key, paramSpec);

  return new String(dcipher.doFinal(asBin(value)));} catch (BadPaddingException e) {

  e.printStackTrace();} catch (NoSuchAlgorithmException e) {e.printStackTrace();} catch (NoSuchPaddingException e) {e.printStackTrace();} catch (InvalidKeyException e) {

  e.printStackTrace();} catch (InvalidAlgorithmParameterException e) {

  e.printStackTrace();} catch (IllegalBlockSizeException e) {

  e.printStackTrace();}

  return "";}

  private String asHex(byte buf[]) {

  StringBuffer strbuf = new StringBuffer(buf.length * 2);

  int i;

  for (i = 0; i < buf.length; i++) {if (((int) buf[i] & 0xff) < 0x10)strbuf.append("0");strbuf.append(Long.toString((int) buf[i] & 0xff, 16));}

  return strbuf.toString();}

  private byte[] asBin(String src) {

  if (src.length() < 1)

  return null;

  byte[] encrypted = new byte[src.length() / 2];

  for (int i = 0; i < src.length() / 2; i++) {

  int high = Integer.parseInt(src.substring(i * 2, i * 2 + 1), 16);

  int low = Integer.parseInt(src.substring(i * 2 + 1, i * 2 + 2), 16);

  encrypted[i] = (byte) (high * 16 + low);}

  return encrypted;}

  public static void main(String args[]) {

  String str = AESEncrypter.getInstance().encrypt("192.168.30.193.123");

  System.out.println(str);

  System.out.println(AESEncrypter.getInstance().decrypt(str));}}

  相關(guān)推薦:計算機軟考程序員備考:程序設(shè)計知識點匯總
       計算機軟考程序員備考:程序設(shè)計知識點匯總
       
文章搜索
軟件水平考試欄目導(dǎo)航
版權(quán)聲明:如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請與我們聯(lián)系800@exam8.com,我們將會及時處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請注明出處。