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