RSA加密--实例demo--有公钥密钥

本文展示了如何使用RSA加密算法进行公钥私钥加密和解密的实例。首先,通过给定标识生成公钥和私钥文件;接着,使用私钥进行加密,公钥进行解密,反之亦然。最后,提供了服务商和客户商加密解密的详细步骤和相关方法。
摘要由CSDN通过智能技术生成

1、由服务商生成通讯双方需要使用的公钥、密钥(通过一个给定的字符串),其中ZHCW0123456789为通过给定的标识,生成公钥文件

PUK.TXT、密钥文件PRK.TXT。


  String[] a = {"ZHCW0123456789"};
  grsak(a);

 

 

 

/**
  *
  * @param args    唯一公钥密钥的生成标识  String[]
  */
 private static void grsak(String[] args) {
  if (args.length > 3) {
   usage();
   return;
  }
  try {
   KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance(
     RSA_INSTANCE_NAME, new BouncyCastleProvider());
   keyPairGenerator.initialize(RSA_KEY_SIZE, new SecureRandom());
   KeyPair keyPair = keyPairGenerator.genKeyPair();
   PublicKey puk = keyPair.getPublic();
   PrivateKey prk = keyPair.getPrivate();
   //16key
   String pkString = encode(puk.getEncoded());
   String skString = encode(prk.getEncoded());
   String prkFile = DEFAULT_PRK_FILE_NAME;
   String pukFile = DEFAULT_PUK_FILE_NAME;
   if (args.length == 2) {
    prkFile = args[1];
   } else if (args.length == 3) {
    prkFile = args[1];
    pukFile = args[2];
   }
   writeBytesToFile(prkFile, skString.getBytes());
   writeBytesToFile(pukFile, pkString.getBytes());
   System.out
     .println("Success to generate RSA key, the keys file are: ");
   if (args.le

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值