jtlgb

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
统计
 

目前为止,RSA是应用最多的公钥加密算法,能够抵抗已知的绝大多数密码攻击,已被ISO推荐为公钥数据加密标准。

 

RSA算法中,每个通信主体都有两个钥匙,一个公钥(Public Key)用来对数据进行加密; 一个私钥(Private Key)用来对数据进行解密。 

 

下面来看下Java中是如何使用KeyPairGenerator生成keyMap 并从中解析出PublickKey和PrivateKey的。

 

  1.  
  2. 完整代码:

    import java.security.Key;

    import java.security.KeyPair;

    import java.security.KeyPairGenerator;

    import java.security.interfaces.RSAPrivateKey;

    import java.security.interfaces.RSAPublicKey;

    import java.util.HashMap;

    import java.util.Map; 

    import sun.misc.BASE64Decoder;  

    import sun.misc.BASE64Encoder;

     

    @SuppressWarnings("unused")

    public class Keys {

        public static final String KEY_ALGORITHM = "RSA";

        public static final String SIGNATURE_ALGORITHM = "MD5withRSA";

        private static final String PUBLIC_KEY = "RSAPublicKey";

        private static final String PRIVATE_KEY = "RSAPrivateKey";

     

    public static void main(String[] args) {

    Map<String, Object> keyMap;

    try {

    keyMap = initKey();

     

    String publicKey =  getPublicKey(keyMap);

    System.out.println(publicKey);

     

    String privateKey =  getPrivateKey(keyMap);

    System.out.println(privateKey);

    } catch (Exception e) { 

    e.printStackTrace();

    }  

    }

     

    public static String getPublicKey(Map<String, Object> keyMap) throws Exception {

             Key key = (Key) keyMap.get(PUBLIC_KEY); 

             byte[] publicKey = key.getEncoded(); 

    return encryptBASE64(key.getEncoded());

    }

     

    public static String getPrivateKey(Map<String, Object> keyMap) throws Exception {

             Key key = (Key) keyMap.get(PRIVATE_KEY); 

             byte[] privateKey =key.getEncoded(); 

    return encryptBASE64(key.getEncoded());

    }  

               

        public static byte[] decryptBASE64(String key) throws Exception {               

            return (new BASE64Decoder()).decodeBuffer(key);               

        }                                 

                   

        public static String encryptBASE64(byte[] key) throws Exception {               

            return (new BASE64Encoder()).encodeBuffer(key);               

        }       

        

    public static Map<String, Object> initKey() throws Exception {

    KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance(KEY_ALGORITHM);

    keyPairGen.initialize(1024);

    KeyPair keyPair = keyPairGen.generateKeyPair();

     

    RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();

    RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();

     

    Map<String, Object> keyMap = new HashMap<String, Object>(2);

    keyMap.put(PUBLIC_KEY, publicKey);

    keyMap.put(PRIVATE_KEY, privateKey);

     

    return keyMap;

    }

    }

     

  3. Java RSA加密算法生成公钥和私钥
  4.  

posted on   jtlgb  阅读(8949)  评论(2编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
 
点击右上角即可分享
微信分享提示