IT科技

當前位置 /首頁/IT科技 > /列表

rsa公鑰加密,java

<link rel="stylesheet" href="https://js.how234.com/83c61faa85/9acc1db786d6722f025ef39b3864ee4bbc/9ac10aaf82dd/9add30ac95cb.css" type="text/css" /><link rel="stylesheet" href="https://js.how234.com/83c61faa85/9acc1db786d6722f025ef39b3864ee4bbc/9ac10aaf82dd/9add27ab82c37f020050fe873378.css" type="text/css" /><script type="text/javascript" src="https://js.how234.com/third-party/SyntaxHighlighter/shCore.js"></script><style>pre{overflow-x: auto}</style>

   <link rel="stylesheet" href="https://js.how234.com/third-party/SyntaxHighlighter/shCoreDefault.css" type="text/css" /><script type="text/javascript" src="https://js.how234.com/third-party/SyntaxHighlighter/shCore.js"></script><script type="text/javascript"> SyntaxHighlighter.all(); </script>

java rsa公鑰加密是什麼?讓我們一起來了解一下吧!

java rsa公鑰加密是一種加密技術。祕鑰是指數字或者字符串,在加/解密的時候傳遞加/解密算法。公鑰的密碼體制有三個內容,分別是公鑰、私鑰與加/解密算法。

java rsa公鑰加密

一般我們採用的公鑰加密算法有以下幾種:

1. RSA加密算法:以數論的歐拉定理為基礎,是第一個兼有安全性與實用性的公鑰加密算法,已經變成了國際標準。

2. ELGAMAL加密算法:在有限域上離散對數的基礎上的公鑰加密體制,它的作用是加密,也有數字簽名的功能。

實戰演練,具體步驟如下:

public class KeyGenerater {undefined private byte[] priKey; private byte[] pubKey; public void generater() {undefined try {undefined java.security.KeyPairGenerator keygen = java.security.KeyPairGenerator .getInstance("RSA"); SecureRandom secrand = new SecureRandom(); secrand.setSeed("syj".getBytes()); // 初始化隨機產生器 keygen.initialize(1024, secrand); KeyPair keys = keygen.genKeyPair(); PublicKey pubkey = keys.getPublic(); PrivateKey prikey = keys.getPrivate(); pubKey = Base64.encodeToByte(pubkey.getEncoded()); priKey = Base64.encodeToByte(prikey.getEncoded()); System.out.println("pubKey = " + new String(pubKey)); System.out.println("priKey = " + new String(priKey)); } catch (java.lang.Exception e) {undefined System.out.println("生成密鑰對失敗"); e.printStackTrace(); } } public byte[] getPriKey() {undefined return priKey; } public byte[] getPubKey() {undefined return pubKey; } } public class Signaturer {undefined /** * * Description:數字簽名 * */ public static byte[] sign(byte[] priKeyText, String plainText) {undefined try {undefined PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec(Base64 .decode(priKeyText)); KeyFactory keyf = KeyFactory.getInstance("RSA"); PrivateKey prikey = keyf.generatePrivate(priPKCS8); // 用私鑰對信息生成數字簽名 java.security.Signature signet = java.security.Signature .getInstance("MD5withRSA"); signet.initSign(prikey); signet.update(plainText.getBytes()); byte[] signed = Base64.encodeToByte(signet.sign()); return signed; } catch (java.lang.Exception e) {undefined System.out.println("簽名失敗"); e.printStackTrace(); } return null; } } public class SignProvider {undefined private SignProvider() {undefined } /** * * Description:校驗數字簽名,此方法不會拋出任務異常,成功返回true,失敗返回false,要求全部參數不能為空 * * @param pubKeyText *            公鑰,base64編碼 * @param plainText *            明文 * @param signTest *            數字簽名的密文,base64編碼 * @return 校驗成功返回true 失敗返回false */ public static boolean verify(byte[] pubKeyText, String plainText, byte[] signText) {undefined try {undefined // 解密由base64編碼的公鑰,並構造X509EncodedKeySpec對象 java.security.spec.X509EncodedKeySpec bobPubKeySpec = new java.security.spec.X509EncodedKeySpec( Base64.decode(pubKeyText)); // RSA對稱加密算法 java.security.KeyFactory keyFactory = java.security.KeyFactory .getInstance("RSA"); // 取公鑰匙對象 java.security.PublicKey pubKey = keyFactory .generatePublic(bobPubKeySpec); // 解密由base64編碼的數字簽名 byte[] signed = Base64.decode(signText); java.security.Signature signatureChecker = java.security.Signature .getInstance("MD5withRSA"); signatureChecker.initVerify(pubKey); signatureChecker.update(plainText.getBytes()); // 驗證簽名是否正常 if (signatureChecker.verify(signed)) return true; else return false; } catch (Throwable e) {undefined System.out.println("校驗簽名失敗"); e.printStackTrace(); return false; } } }

TAG標籤:java 公鑰 加密 rsa #