亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

對稱加密算法-DES,3DES,AES

2019-11-10 20:38:17
字體:
來源:轉載
供稿:網友

1.jdk與bc實現DES算法:

package com.samlai.security;import java.security.Key;import java.security.NoSuchAlgorithmException;import java.security.Security;import javax.crypto.Cipher;import javax.crypto.KeyGenerator;import javax.crypto.SecretKey;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESKeySpec;import org.apache.commons.codec.binary.Hex;import org.bouncycastle.jce.PRovider.BouncyCastleProvider;public class DesStudy {	/**	 * 對稱加密算法---DES	 * 	 */	private static String STR = "one type of security:DES";	public static void main(String[] args) {		jdkDES();		bcDES();	}	// jdk的DES	public static void jdkDES() {		try {			// 生成key			KeyGenerator keyGenerator = KeyGenerator.getInstance("DES");			//打斷點可以查看對應keyGenerator.getProvider()是哪個class:BC			keyGenerator.getProvider();			keyGenerator.init(56);			SecretKey secretKey = keyGenerator.generateKey();			byte[] bytesKey = secretKey.getEncoded();			// Key轉換			DESKeySpec desKeySpec = new DESKeySpec(bytesKey);			SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");			Key converSecretKey = factory.generateSecret(desKeySpec);			// 加密			Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");			cipher.init(Cipher.ENCRYPT_MODE, converSecretKey);			byte[] result = cipher.doFinal(STR.getBytes());			System.out					.println("jdk des encode: " + Hex.encodeHexString(result));			// 解密			cipher.init(Cipher.DECRYPT_MODE, converSecretKey);			result = cipher.doFinal(result);			System.out.println("jdk des decode: " + new String(result));		} catch (Exception e) {			e.printStackTrace();		}	}		// bc方式的DES	public static void bcDES() {		try {						Security.addProvider(new BouncyCastleProvider());						// 生成key			KeyGenerator keyGenerator = KeyGenerator.getInstance("DES","BC");			//打斷點可以查看對應keyGenerator.getProvider()是哪個class:BC			keyGenerator.getProvider();			keyGenerator.init(56);			SecretKey secretKey = keyGenerator.generateKey();			byte[] bytesKey = secretKey.getEncoded();			// Key轉換			DESKeySpec desKeySpec = new DESKeySpec(bytesKey);			SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");			Key converSecretKey = factory.generateSecret(desKeySpec);			// 加密			Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");			cipher.init(Cipher.ENCRYPT_MODE, converSecretKey);			byte[] result = cipher.doFinal(STR.getBytes());			System.out					.println("bc des encode: " + Hex.encodeHexString(result));			// 解密			cipher.init(Cipher.DECRYPT_MODE, converSecretKey);			result = cipher.doFinal(result);			System.out.println("bc des decode: " + new String(result));		} catch (Exception e) {			e.printStackTrace();		}	}}

運行的結果是:

jdk des encode: 78a3c4cff016308a7d916fd3f072d35682c4fd7bdb1ef9357cfc890d711ce6dajdk des decode: one type of security:DESbc des encode: 6b0daa8478df9ed8ae70f2e442e0eedd996aa8412ac951859bc7a00188cb1c63bc des decode: one type of security:DES

2.三重DES使用jdk,bc方式進行實現:

package com.samlai.security;import java.security.Key;import java.security.SecureRandom;import java.security.Security;import javax.crypto.Cipher;import javax.crypto.KeyGenerator;import javax.crypto.SecretKey;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESKeySpec;import javax.crypto.spec.DESedeKeySpec;import org.apache.commons.codec.binary.Hex;import org.bouncycastle.jce.provider.BouncyCastleProvider;import org.bouncycastle.jce.provider.JCEBlockCipher.DESede;public class ThreeDesStudy {	/**	 * 為什么使用3DES: 補充DES的不足,因為其違反了柯克霍夫原則,與安全性問題	 * 優點: 1.密鑰長度增強 2.迭代次數提高	 */	private static String STR = "one type of security:3DES";	public static void main(String[] args) {		jdk3DES();		bc3DES();	}	// jdk的DES	public static void jdk3DES() {		try {			// 生成key			KeyGenerator keyGenerator = KeyGenerator.getInstance("DESede");			// 打斷點可以查看對應keyGenerator.getProvider()是哪個class:BC			keyGenerator.getProvider();			// 長度比des長,比如168位			// keyGenerator.init(168);			keyGenerator.init(new SecureRandom());			SecretKey secretKey = keyGenerator.generateKey();			byte[] bytesKey = secretKey.getEncoded();			// Key轉換			DESedeKeySpec desKeySpec = new DESedeKeySpec(bytesKey);			SecretKeyFactory factory = SecretKeyFactory.getInstance("DESede");			Key converSecretKey = factory.generateSecret(desKeySpec);			// 加密			Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");			cipher.init(Cipher.ENCRYPT_MODE, converSecretKey);			byte[] result = cipher.doFinal(STR.getBytes());			System.out.println("jdk 3des encode: "					+ Hex.encodeHexString(result));			// 解密			cipher.init(Cipher.DECRYPT_MODE, converSecretKey);			result = cipher.doFinal(result);			System.out.println("jdk 3des decode: " + new String(result));		} catch (Exception e) {			e.printStackTrace();		}	}	// bc方式的3DES	public static void bc3DES() {		try {			Security.addProvider(new BouncyCastleProvider());			// 生成key			KeyGenerator keyGenerator = KeyGenerator.getInstance("DESede", "BC");			// 打斷點可以查看對應keyGenerator.getProvider()是哪個class:BC			keyGenerator.getProvider();			keyGenerator.init(new SecureRandom());			SecretKey secretKey = keyGenerator.generateKey();			byte[] bytesKey = secretKey.getEncoded();			// Key轉換			DESedeKeySpec desKeySpec = new DESedeKeySpec(bytesKey);			SecretKeyFactory factory = SecretKeyFactory.getInstance("DESede");			Key converSecretKey = factory.generateSecret(desKeySpec);			// 加密			Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");			cipher.init(Cipher.ENCRYPT_MODE, converSecretKey);			byte[] result = cipher.doFinal(STR.getBytes());			System.out					.println("bc 3des encode: " + Hex.encodeHexString(result));			// 解密			cipher.init(Cipher.DECRYPT_MODE, converSecretKey);			result = cipher.doFinal(result);			System.out.println("bc 3des decode: " + new String(result));		} catch (Exception e) {			e.printStackTrace();		}	}}運行的結果是:

jdk 3des encode: 1db97710868ab0cb03c0f7c5f919a9904d8b19baad82828f7384a70555e141a7jdk 3des decode: one type of security:3DESbc 3des encode: e8c29dc519020175d5603aefb46aa586ae0f37afdc67dfcfcb4706b92fbe40fcbc 3des decode: one type of security:3DES

3.jdk,bc實現AES的算法:

package com.samlai.security;import java.security.Key;import java.security.Security;import javax.crypto.Cipher;import javax.crypto.KeyGenerator;import javax.crypto.SecretKey;import javax.crypto.spec.SecretKeySpec;import org.apache.commons.codec.binary.Base64;import org.bouncycastle.jce.provider.BouncyCastleProvider;public class AESStudy {	/**	 * 比較普遍使用,效率比3DES效果高,安全性也比較高,高級,DES替代者	 */	private static String STR = "one type of security:AES";		public static void main(String[] args) {		jdkAES();		bcAES();	}		//jdk實現:256位限制性政策性文件	public static void jdkAES(){		try {			//生成key			KeyGenerator keyGenerator=KeyGenerator.getInstance("AES");			//可以是128 256//			keyGenerator.init(new SecureRandom());			keyGenerator.init(128);			SecretKey secretKey=keyGenerator.generateKey();			byte[] keyBytes=secretKey.getEncoded();			//key的轉換			Key key=new SecretKeySpec(keyBytes, "AES");			//加密			Cipher cipher=Cipher.getInstance("AES/ECB/PKCS5Padding");			cipher.init(Cipher.ENCRYPT_MODE, key);			byte[] result=cipher.doFinal(STR.getBytes());			System.out.println("jdk AES encode: "+Base64.encodeBase64String(result));						//解密			cipher.init(Cipher.DECRYPT_MODE, key);			result=cipher.doFinal(result);			System.out.println("jdk AES decode:"+new String(result));		} catch (Exception e) {			e.printStackTrace();		}	}	   //bc實現AES   public static void bcAES(){	   	try {		    Security.addProvider(new BouncyCastleProvider());		    //生成key		    KeyGenerator keyGenerator=KeyGenerator.getInstance("AES","BC");		    keyGenerator.getProvider();		   //可以是128 256			keyGenerator.init(128);			SecretKey secretKey=keyGenerator.generateKey();			byte[] keyBytes=secretKey.getEncoded();			//key的轉換			Key key=new SecretKeySpec(keyBytes, "AES");			//加密			Cipher cipher=Cipher.getInstance("AES/ECB/PKCS5Padding");			cipher.init(Cipher.ENCRYPT_MODE, key);			byte[] result=cipher.doFinal(STR.getBytes());			System.out.println("bc AES encode: "+Base64.encodeBase64String(result));						//解密			cipher.init(Cipher.DECRYPT_MODE, key);			result=cipher.doFinal(result);			System.out.println("bc AES decode:"+new String(result));	} catch (Exception e) {		e.printStackTrace();	}	   }	}

運行的結果:

jdk AES encode: 1OYQyHApgsyqFXRolOPing39HY9yBfAJGF0tagOEmEA=jdk AES decode:one type of security:AESbc AES encode: PbvF8JGq8B4x7NQtO6t2/qY/muDb/eijHa9zGIxQj7k=bc AES decode:one type of security:AES

4.使用jdk實現PBE算法:

package com.samlai.security.xEs;import java.security.Key;import java.security.SecureRandom;import javax.crypto.Cipher;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.PBEKeySpec;import javax.crypto.spec.PBEParameterSpec;import org.apache.commons.codec.binary.Base64;public class PbeStudy {	/**	 * PBE算法結合了消息摘要算法和對稱加密算法的優點	 * PBE(PassWord Based Encryption)基于口令加密  -- Salt	 * 對已有算法的包裝	 * JDK BC	 * 鹽	 * PBEWithmd5AndDES	 */	private static String STR = "one type of security:PBE";		public static void main(String[] args) {		jdkPBE();	}				//jdk實現PBE	public static void jdkPBE(){		try {			//初始化鹽			SecureRandom random=new SecureRandom();			byte[] salt=random.generateSeed(8);						//口令與密鑰			String password="studySecurity";			PBEKeySpec pbeKeySpec=new PBEKeySpec(password.toCharArray());			SecretKeyFactory factory=SecretKeyFactory.getInstance("PBEWITHMD5andDES");			Key key=factory.generateSecret(pbeKeySpec);						//加密			PBEParameterSpec pbeParameterSpec=new PBEParameterSpec(salt, 100);			Cipher cipher=Cipher.getInstance("PBEWITHMD5andDES");			cipher.init(Cipher.ENCRYPT_MODE, key,pbeParameterSpec);			byte[] result=cipher.doFinal(STR.getBytes());			System.out.println("jdk PBE encode: "+Base64.encodeBase64String(result));						//解密			cipher.init(Cipher.DECRYPT_MODE, key,pbeParameterSpec);			result=cipher.doFinal(result);			System.out.println("jdk PBE decode: "+new String(result));		} catch (Exception e) {			e.printStackTrace();		}	}}運行的結果:

jdk PBE encode: LMjza18BhB0jgGmngAGwW+cb3sblayHKHB/tmDFM9m0=jdk PBE decode: one type of security:PBE


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人jvid在线播放| 青青久久av北条麻妃海外网| 国产精品久久久久av| 日韩精品免费在线视频观看| 日韩av电影国产| 一区二区三区在线播放欧美| 欧美日韩一区二区三区| 亚洲国产精彩中文乱码av| 日韩激情第一页| 久久久国产一区| 国产精品十八以下禁看| 欧美精品久久久久| 国产亚洲精品一区二555| 国产成人精品亚洲精品| 日韩亚洲综合在线| 欧美大码xxxx| 国内免费久久久久久久久久久| 日本成人黄色片| 久久久国产一区二区| 久久久久久一区二区三区| 成人看片人aa| 亚洲国产99精品国自产| 国产成人激情小视频| 成人免费激情视频| 美日韩精品免费观看视频| 亚洲中国色老太| 国产69久久精品成人| 中文字幕亚洲欧美| 国产精品青草久久久久福利99| 91精品国产高清久久久久久| 久久九九精品99国产精品| 91精品国产成人| 日韩在线播放视频| 91香蕉电影院| 88国产精品欧美一区二区三区| 97视频在线观看免费高清完整版在线观看| 欧美久久精品午夜青青大伊人| 在线中文字幕日韩| 久久精品一区中文字幕| 亚洲精品资源在线| 日韩精品久久久久久久玫瑰园| 日韩精品视频免费专区在线播放| 亚洲欧美成人一区二区在线电影| 精品亚洲一区二区三区四区五区| 欧美日韩国产成人在线观看| 欧美激情在线狂野欧美精品| 国产一区二区香蕉| 亚洲国产美女精品久久久久∴| 日韩在线免费高清视频| 欧美日韩国产第一页| 欧美黑人性视频| 久久精品福利视频| 亚洲综合成人婷婷小说| 中文字幕日韩欧美精品在线观看| 日韩欧美一区二区三区久久| 日韩精品在线视频观看| 久久综合伊人77777| 国产成人精品国内自产拍免费看| 亚洲精品电影在线| 国产欧美日韩中文字幕| 伊人激情综合网| 日本最新高清不卡中文字幕| 亚洲欧洲在线观看| 中文字幕视频一区二区在线有码| 亚洲电影免费观看高清完整版在线| 欧美日韩成人黄色| 欧美激情一二区| 日韩欧美一区二区在线| 亚洲第一精品电影| 在线观看日韩视频| 91沈先生在线观看| 欧美日本国产在线| 中文字幕精品www乱入免费视频| 成人精品在线观看| 欧美大片欧美激情性色a∨久久| 一区二区三区日韩在线| 精品美女国产在线| 亚洲黄一区二区| 一区二区欧美亚洲| 岛国视频午夜一区免费在线观看| 美日韩在线视频| 狠狠色香婷婷久久亚洲精品| 亚洲激情在线观看视频免费| 国产精品久久久久高潮| 久久久久久九九九| 日韩暖暖在线视频| 乱亲女秽乱长久久久| 中文欧美在线视频| 国产午夜精品视频免费不卡69堂| 91久久精品国产91性色| 一区二区三区亚洲| 91日本在线视频| 亚洲美女福利视频网站| 91精品国产99| 亚洲free性xxxx护士hd| 日韩精品有码在线观看| 国产经典一区二区| 欧美黑人又粗大| 国内精品一区二区三区四区| 国产亚洲欧洲高清一区| 九九热这里只有在线精品视| 欧美日韩国产限制| 亚洲综合精品一区二区| 国产精品麻豆va在线播放| 国产一区视频在线播放| 中文字幕欧美日韩va免费视频| 日韩高清av在线| 视频一区视频二区国产精品| 久久99精品久久久久久噜噜| 视频在线一区二区| 欧美在线一级va免费观看| 亚州欧美日韩中文视频| 亚洲欧美一区二区三区情侣bbw| 久久艹在线视频| 日韩在线观看免费高清完整版| 精品国产一区二区在线| 亚洲成人激情在线| 亚洲黄色在线看| 国产精品一区二区三区久久久| 欧美激情中文网| 国内精品久久久久久久久| 日韩在线欧美在线国产在线| 精品精品国产国产自在线| 国产精品户外野外| 精品国产欧美一区二区五十路| 国产精品久久久久久久9999| 亚洲伊人久久大香线蕉av| 亚洲欧美日韩视频一区| 亚洲国产精品悠悠久久琪琪| 欧美成人黑人xx视频免费观看| 日本高清+成人网在线观看| 国产精品福利片| 欧美极品少妇xxxxⅹ裸体艺术| 久久精品中文字幕一区| 91精品国产91久久久久久久久| 自拍偷拍亚洲欧美| 日韩欧美在线免费观看| 亚洲最大中文字幕| 最近2019中文字幕在线高清| 成人免费福利在线| 亚洲精品日韩在线| 亚洲欧美在线一区二区| 欧美福利视频在线| 91免费看国产| 国产91精品久久久久久| 日本午夜精品理论片a级appf发布| 国产精品电影久久久久电影网| 成人免费xxxxx在线观看| 欧美激情奇米色| 久久精品国产精品| 91a在线视频| 精品亚洲一区二区三区在线观看| 欧美夫妻性生活视频| 欧美日韩中文字幕日韩欧美| 亚洲自拍偷拍第一页| 在线精品91av| 中日韩美女免费视频网址在线观看| 亚洲在线观看视频网站| 国产精品极品尤物在线观看| 亚洲欧美日韩精品久久| 久久国产精品久久久久久久久久| 亚洲一区二区三区四区在线播放| 国内精品久久久久影院优| 中文字幕av一区中文字幕天堂|