当前位置:   article > 正文

对称加密算法_pbekeyspec c++

pbekeyspec c++

1、对称加密:采用单钥对信息进行加密和解密,即同一个秘钥既可以对信息进行加密,也可以进行解密。此类型称之为对称加密。特点速度快,常用于对大量数据信息或文件加密时使用。常用例子:DES、IDEA、RC2、RC4、SKIPJACK、RC5、AES。

优点:速度快,对称性加密通常在消息发送方需要加密大量数据时使用,算法公开、计算量小、加密速度快、加密效率高。

缺点:在数据传送前,发送方和接收方必须商定好秘钥,然后 使双方都能保存好秘钥。其次如果一方的秘钥被泄露,那么加密信息也就不安全了。另外,每对用户每次使用对称加密算法时,都需要使用其他人不知道的唯一秘 钥,这会使得收、发双方所拥有的钥匙数量巨大,密钥管理成为双方的负担

AES:密钥的长度可以为128、192和256位,也就是16个字节、24个字节和32个字节

DES:密钥的长度64位,8个字节。

1.AES加密算法

  1. package com.yirong;
  2. import java.security.Key;
  3. import java.security.SecureRandom;
  4. import javax.crypto.Cipher;
  5. import javax.crypto.KeyGenerator;
  6. import javax.crypto.SecretKey;
  7. import javax.crypto.spec.SecretKeySpec;
  8. import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
  9. public class Test_AES {
  10. //加密的内容
  11. private static String src = "security AES";
  12. public static void main(String[] args) {
  13. jdkAES();
  14. }
  15. public static void jdkAES() {
  16. try {
  17. //创建AES的Key生产者
  18. KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
  19. // 利用用户密码作为随机数初始化出
  20. keyGenerator.init(new SecureRandom());
  21. // 根据用户密码,生成一个密钥
  22. SecretKey secretKey = keyGenerator.generateKey();
  23. // 返回基本编码格式的密钥,如果此密钥不支持编码,则返回null
  24. byte[] keyBytes = secretKey.getEncoded();
  25. // 转换为AES专用密钥
  26. Key key = new SecretKeySpec(keyBytes, "AES");
  27. // 创建密码器
  28. Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
  29. // 初始化为加密模式的密码器
  30. cipher.init(Cipher.ENCRYPT_MODE, key);
  31. //加密
  32. byte[] result = cipher.doFinal(src.getBytes());
  33. System.out.println("jdk aes encrypt:" + Base64.encode(result));
  34. // 初始化为解密模式的密码器
  35. cipher.init(Cipher.DECRYPT_MODE, key);
  36. //解密
  37. result = cipher.doFinal(result);
  38. System.out.println("jdk aes encrypt:" + new String(result));
  39. } catch (Exception e) {
  40. // TODO Auto-generated catch block
  41. e.printStackTrace();
  42. }
  43. }
  44. }

2.DES加密算法

  1. package com.yirong;
  2. import java.security.Key;
  3. import java.security.MessageDigest;
  4. import java.security.NoSuchAlgorithmException;
  5. import java.security.SecureRandom;
  6. import java.security.Security;
  7. import javax.crypto.Cipher;
  8. import javax.crypto.KeyGenerator;
  9. import javax.crypto.SecretKey;
  10. import javax.crypto.SecretKeyFactory;
  11. import javax.crypto.spec.DESKeySpec;
  12. import javax.crypto.spec.DESedeKeySpec;
  13. import org.apache.commons.codec.binary.Hex;
  14. public class Test_DES {
  15. //加密的内容
  16. private static String src = "security sha";
  17. public static void main(String[] args) {
  18. jdk3DES();
  19. jdkDES();
  20. }
  21. public static void jdkDES() {
  22. try {
  23. //生成一个key
  24. KeyGenerator keyGenerator;
  25. keyGenerator = KeyGenerator.getInstance("DES");
  26. keyGenerator.init(56);
  27. SecretKey secretKey = keyGenerator.generateKey();
  28. //得到key数组
  29. byte[] bytesKey = secretKey.getEncoded();
  30. //key转换
  31. DESKeySpec desKeySpec = new DESKeySpec(bytesKey);
  32. //加密方式
  33. SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");
  34. //生成的秘钥
  35. Key secret = factory.generateSecret(desKeySpec);
  36. //加密 加解密算法,工作模式,填充方式
  37. Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
  38. cipher.init(Cipher.ENCRYPT_MODE, secret);
  39. byte[] result = cipher.doFinal(src.getBytes());
  40. System.out.println("jdk des encrypt: " + Hex.encodeHexString(result));
  41. //解密
  42. cipher.init(Cipher.DECRYPT_MODE, secret);
  43. result = cipher.doFinal(result);
  44. System.out.println("jdk des encrypt: " + new String(result));
  45. } catch (Exception e) {
  46. e.printStackTrace();
  47. }
  48. }
  49. public static void jdk3DES() {
  50. try {
  51. //生成一个key
  52. KeyGenerator keyGenerator;
  53. keyGenerator = KeyGenerator.getInstance("DESede");
  54. //生成的长度
  55. //keyGenerator.init(128);
  56. keyGenerator.init(new SecureRandom());
  57. SecretKey secretKey = keyGenerator.generateKey();
  58. //得到key数组
  59. byte[] bytesKey = secretKey.getEncoded();
  60. //key转换
  61. DESedeKeySpec desKeySpec = new DESedeKeySpec(bytesKey);
  62. //加密方式
  63. SecretKeyFactory factory = SecretKeyFactory.getInstance("DESede");
  64. //生成的秘钥
  65. Key secret = factory.generateSecret(desKeySpec);
  66. //加密 加解密算法,工作模式,填充方式
  67. Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
  68. cipher.init(Cipher.ENCRYPT_MODE, secret);
  69. byte[] result = cipher.doFinal(src.getBytes());
  70. System.out.println("jdk des encrypt: " + Hex.encodeHexString(result));
  71. //解密
  72. cipher.init(Cipher.DECRYPT_MODE, secret);
  73. result = cipher.doFinal(result);
  74. System.out.println("jdk des encrypt: " + new String(result));
  75. } catch (Exception e) {
  76. e.printStackTrace();
  77. }
  78. }
  79. }

3.PBE加密算法

  1. package com.yirong;
  2. import java.security.Key;
  3. import java.security.NoSuchAlgorithmException;
  4. import java.security.SecureRandom;
  5. import javax.crypto.Cipher;
  6. import javax.crypto.SecretKey;
  7. import javax.crypto.SecretKeyFactory;
  8. import javax.crypto.spec.PBEKeySpec;
  9. import javax.crypto.spec.PBEParameterSpec;
  10. import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
  11. public class Test_PBE {
  12. public static void main(String[] args) {
  13. jdkPbe();
  14. }
  15. //加密的内容
  16. private static String src = "security pbe";
  17. public static void jdkPbe() {
  18. try {
  19. //初始化盐
  20. SecureRandom random = new SecureRandom();
  21. byte[] salt = random.generateSeed(8);
  22. //口令密钥
  23. String password = "123";
  24. PBEKeySpec pbeKeySpec = new PBEKeySpec(password.toCharArray());
  25. SecretKeyFactory factory = SecretKeyFactory.getInstance("PBEWITHMD5andDES");
  26. Key key = factory.generateSecret(pbeKeySpec);
  27. //加密
  28. PBEParameterSpec parameterSpec = new PBEParameterSpec(salt, 100);
  29. Cipher cipher = Cipher.getInstance("PBEWITHMD5andDES");
  30. cipher.init(Cipher.ENCRYPT_MODE, key,parameterSpec);
  31. byte[] result = cipher.doFinal(src.getBytes());
  32. System.out.println("jdk pbe encrypt:" + Base64.encode(result));
  33. //解密
  34. cipher.init(Cipher.DECRYPT_MODE, key,parameterSpec);
  35. result = cipher.doFinal(result);
  36. System.out.println("jdk pde encrypt:" + new String(result));
  37. } catch (Exception e) {
  38. // TODO Auto-generated catch block
  39. e.printStackTrace();
  40. }
  41. }
  42. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/天景科技苑/article/detail/990978
推荐阅读
相关标签
  

闽ICP备14008679号