当前位置:   article > 正文

【算法】Java实现RSA算法_java rsa

java rsa

1.什么是RSA算法

RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,它是目前最广泛使用的公钥加密算法之一。RSA算法是由三位密码学家(Ron Rivest、Adi Shamir、Leonard Adleman)在1977年提出的。

RSA算法基于大数因子分解的数学难题,它使用一对密钥:公钥和私钥。公钥用于加密数据,私钥用于解密数据。公钥可以公开分享给其他人,而私钥必须保密。

RSA算法的主要原理如下:

  1. 选择两个不同的大素数p和q。
  2. 计算n = p * q,n被称为模数(modulus)。
  3. 计算欧拉函数φ(n) = (p - 1) * (q - 1)。
  4. 选择一个小于φ(n)且与φ(n)互质的整数e,e被称为公钥指数(public exponent)。
  5. 计算满足以下条件的整数d:(d * e) % φ(n) = 1,d被称为私钥指数(private exponent)。
  6. 公钥由(n, e)组成,私钥由(n, d)组成。

加密时,将明文m转换为整数M,然后使用公式C = M^e mod n对明文进行加密,得到密文C。解密时,使用私钥指数d,对密文C进行解密得到明文M,再将M转换为明文m。

RSA算法的安全性基于大素数因子分解问题的难度,即找到n的两个大素数因子p和q。当前,只要使用足够大的密钥长度,如2048位或以上,RSA算法被认为是安全的。

RSA算法不仅可以用于加密和解密数据,还可以用于数字签名、密钥协商和密钥交换等密码学应用。

总结来说,RSA是一种非对称加密算法,使用公钥加密数据,私钥解密数据。它的安全性基于大素数因子分解问题的难度。RSA算法在现代密码学中起着重要的作用,并被广泛应用于安全通信和数据保护领域。

2.使用Java实现RSA算法加密

  1. import java.security.KeyPair;
  2. import java.security.KeyPairGenerator;
  3. import java.security.PrivateKey;
  4. import java.security.PublicKey;
  5. import java.security.Signature;
  6. import java.util.Base64;
  7. public class RSAExample {
  8. public static void main(String[] args) throws Exception {
  9. String plainText = "Hello, World!";
  10. // 生成密钥对
  11. KeyPair keyPair = generateKeyPair();
  12. // 获取公钥和私钥
  13. PublicKey publicKey = keyPair.getPublic();
  14. PrivateKey privateKey = keyPair.getPrivate();
  15. // 使用公钥加密
  16. byte[] encryptedBytes = encrypt(plainText, publicKey);
  17. String encryptedText = Base64.getEncoder().encodeToString(encryptedBytes);
  18. System.out.println("Encrypted Text: " + encryptedText);
  19. // 使用私钥解密
  20. byte[] decryptedBytes = decrypt(encryptedBytes, privateKey);
  21. String decryptedText = new String(decryptedBytes);
  22. System.out.println("Decrypted Text: " + decryptedText);
  23. // 使用私钥签名
  24. byte[] signatureBytes = sign(plainText, privateKey);
  25. String signatureText = Base64.getEncoder().encodeToString(signatureBytes);
  26. System.out.println("Signature: " + signatureText);
  27. // 使用公钥验证签名
  28. boolean isVerified = verify(plainText, signatureBytes, publicKey);
  29. System.out.println("Signature Verified: " + isVerified);
  30. }
  31. public static KeyPair generateKeyPair() throws Exception {
  32. KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
  33. keyPairGenerator.initialize(2048); // 密钥长度为2048位
  34. return keyPairGenerator.generateKeyPair();
  35. }
  36. public static byte[] encrypt(String plainText, PublicKey publicKey) throws Exception {
  37. Cipher cipher = Cipher.getInstance("RSA");
  38. cipher.init(Cipher.ENCRYPT_MODE, publicKey);
  39. return cipher.doFinal(plainText.getBytes());
  40. }
  41. public static byte[] decrypt(byte[] encryptedBytes, PrivateKey privateKey) throws Exception {
  42. Cipher cipher = Cipher.getInstance("RSA");
  43. cipher.init(Cipher.DECRYPT_MODE, privateKey);
  44. return cipher.doFinal(encryptedBytes);
  45. }
  46. public static byte[] sign(String plainText, PrivateKey privateKey) throws Exception {
  47. Signature signature = Signature.getInstance("SHA256withRSA");
  48. signature.initSign(privateKey);
  49. signature.update(plainText.getBytes());
  50. return signature.sign();
  51. }
  52. public static boolean verify(String plainText, byte[] signatureBytes, PublicKey publicKey) throws Exception {
  53. Signature signature = Signature.getInstance("SHA256withRSA");
  54. signature.initVerify(publicKey);
  55. signature.update(plainText.getBytes());
  56. return signature.verify(signatureBytes);
  57. }
  58. }

在这个示例中,我们使用Java的java.security包提供的RSA加密算法。generateKeyPair方法用于生成RSA密钥对,encrypt方法用于使用公钥加密数据,decrypt方法用于使用私钥解密数据,sign方法用于使用私钥对数据进行签名,verify方法用于使用公钥验证签名。

示例中使用的密钥长度为2048位。在实际应用中,可以根据安全性要求选择更长的密钥长度。

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

闽ICP备14008679号