java生成公钥秘钥

java自带有秘钥公钥生成工具,位于JAVA_HOME的bin目录下,可以直接在命令行调用。

  1. 采用RSA算法生成秘钥和公钥
    keytool -genkeypair -alias mykey -keyalg RSA -keypass mykeypassword -keystore mk.keystore -storepass meykeystorepassword
    其中
    -alias 为秘钥名称
    -keyalg 为生成秘钥所使用的算法,常用的为RSA
    -keypass 为秘钥的密码
    -keystore 为秘钥库文件
    -storepass 为秘钥库密码
    运行以上命令,即可在当前文件夹下面生成mk.keystore证书文件。

  2. 查看证书信息
    keytool -list -keystore mk.keystore

  3. 移除证书中的秘钥
    keytool -delete -alias mykey -keystore mk.keystore

  4. 使用openssl导出公钥
    keytool -list -rfc --keystore mk.keystore | openssl x509 -inform pem -pubkey
    将公钥拷贝到文本文件中,合并为一行,即可给需要的地方分发。

windows系统需要安装才能使用openssl工具:http://slproweb.com/products/Win32OpenSSL.html
安装完成后需要配置环境变量。

Java生成密钥的实例    //产生单钥加密的密钥(myKey)   KeyGenerator keyGenerator = KeyGenerator.getInstance("DESede"); //采用DESede算法   keyGenerator.init(168); //选择DESede算法,密钥长度为112位或168位   Key myKey = keyGenerator.generateKey(); //生成密钥   System.out.println("得到单钥加密密钥");   //产生双钥的密钥对(keyPair)   KeyPairGenerator keyPairGenerator=KeyPairGenerator.getInstance("RSA"); //采用RSA算法   keyPairGenerator.initialize(1024); //指定密钥长度为1024位   KeyPair keyPair = keyPairGenerator.generateKeyPair(); //生成密钥对   System.out.println("生成张三的公钥对");   //保存公钥的字节数组   File f = new File("publicKey.dat"); //保存公钥到文件publicKey.dat   FileOutputStream fout = new FileOutputStream(f);   fout.write(keyPair.getPublic().getEncoded()); //得到公钥的字节数组   fout.close(); //关闭文件输出流   System.out.println("保存公钥到文件: " f.getAbsolutePath());   //用Java对象序列化保存私钥,通常应对私钥加密后再保存   ObjectOutputStream oout = new ObjectOutputStream(new FileOutputStream("privateKey.dat")); //保存私钥到文件privateKey.dat   oout.writeObject(keyPair.getPrivate()); //序列化私钥   oout.close(); //关闭输出流   System.err.println("保存私钥到: privateKey.dat");   //从文件中得到公钥编码的字节数组   FileInputStream fin = new FileInputStream("publicKey.dat"); //打天publicKey.dat   ByteArrayOutputStream baout = new ByteArrayOutputStream(); //用于写入文件的字节流   int aByte = 0;   while ((aByte = fin.read())!= -1) //从文件读取一个字节   {    baout.write(aByte); //写入一个字节   }   fin.close(); //关闭文件输入流   byte[] keyBytes = baout.toByteArray(); //得到公钥的字节数组   baout.close(); //关闭字节数组输出流
首先,你需要使用 Java 中的 `java.security` 包来生成 SM2 密钥对,然后将密钥转换为十六进制格式。具体步骤如下: 1. 生成 SM2 密钥对。可以使用 `KeyPairGenerator` 类来生成密钥对: ```java KeyPairGenerator keyGen = KeyPairGenerator.getInstance("SM2", "BC"); // 初始化密钥生成器 SecureRandom random = new SecureRandom(); // 初始化随机数生成器 keyGen.initialize(256, random); // 设置密钥长度和随机数生成器 KeyPair keyPair = keyGen.generateKeyPair(); // 生成密钥对 ``` 2. 获取公钥和私钥,并将它们转换为十六进制格式: ```java PublicKey publicKey = keyPair.getPublic(); // 获取公钥 PrivateKey privateKey = keyPair.getPrivate(); // 获取私钥 String publicKeyHex = Hex.encodeHexString(publicKey.getEncoded()); // 将公钥转换为十六进制格式 String privateKeyHex = Hex.encodeHexString(privateKey.getEncoded()); // 将私钥转换为十六进制格式 ``` 3. 使用公钥和私钥进行加密和解密。可以使用 `Cipher` 类来进行加密和解密: ```java String plaintext = "Hello, world!"; // 要加密的明文 Cipher cipher = Cipher.getInstance("SM2", "BC"); // 初始化加密器 cipher.init(Cipher.ENCRYPT_MODE, publicKey); // 设置加密模式和公钥 byte[] ciphertext = cipher.doFinal(plaintext.getBytes("UTF-8")); // 加密明文 System.out.println("Ciphertext: " + Hex.encodeHexString(ciphertext)); // 输出密文 cipher.init(Cipher.DECRYPT_MODE, privateKey); // 设置解密模式和私钥 byte[] decrypted = cipher.doFinal(ciphertext); // 解密密文 System.out.println("Decrypted text: " + new String(decrypted, "UTF-8")); // 输出明文 ``` 注意,上述代码中的 `BC` 是 Bouncy Castle 提供的一个加解密算法库,在使用 SM2 算法时需要将其添加到 Java 的安全提供程序列表中。你可以在程序入口处添加以下代码: ```java Security.addProvider(new BouncyCastleProvider()); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值