package com.gaia.family.mart.gis.common.utils;
import cn.hutool.core.codec.Base64;
import cn.hutool.crypto.SecureUtil;
import cn.hutool.crypto.asymmetric.KeyType;
import cn.hutool.crypto.asymmetric.RSA;
import lombok.extern.slf4j.Slf4j;
import java.security.KeyPair;
import java.security.PrivateKey;
import java.security.PublicKey;
@Slf4j
public class RSAUtils {
public static final String ENCRYPT_TYPE = "RSA";
/**
* 公钥加密
* @param content 要加密的内容
* @param publicKey 公钥
*/
public static String encrypt(String content, String publicKey) {
try{
RSA rsa=new RSA(null,publicKey);
return rsa.encryptBase64(content, KeyType.PublicKey);
} catch (Exception e){
e.printStackTrace();
}
return null;
}
/**
* 私钥解密
* @param content 要解密的内容
* @param privateKey 私钥
*/
public static String decrypt(String content, String privateKey) {
try {
RSA rsa=new RSA(privateKey,null);
return rsa.decryptStr(content, KeyType.PrivateKey);
} catch (Exception e){
e.printStackTrace();
}
return null;
}
/**
* 生成公钥私钥
*/
public static void main(String[] args) {
try {
KeyPair pair=SecureUtil.generateKeyPair(ENCRYPT_TYPE);
PrivateKey privateKey=pair.getPrivate();
PublicKey publicKey=pair.getPublic();
// 获取 公钥和私钥 的 编码格式(通过该 编码格式 可以反过来 生成公钥和私钥对象)
byte[] pubEncBytes=publicKey.getEncoded();
byte[] priEncBytes=privateKey.getEncoded();
// 把公钥和私钥的编码格式转换为Base64文本
String pubEncBase64=Base64.encode(pubEncBytes);
String priEncBase64=Base64.encode(priEncBytes);
log.info("公钥: {}", pubEncBase64);
log.info("私钥: {}", priEncBase64);
} catch (Exception e){
e.printStackTrace();
}
}
}
评论0