207 lines
8.7 KiB
Java
207 lines
8.7 KiB
Java
/*
|
|
* Copyright (c) 2016-2021. 西安屹城兴软件服务 All rights reserved.
|
|
*/
|
|
package com.ruoyi.common.utils;
|
|
|
|
import com.alibaba.fastjson.JSON;
|
|
import com.ruoyi.common.utils.sign.Md5Utils;
|
|
import org.apache.commons.codec.binary.Base64;
|
|
|
|
import javax.crypto.Cipher;
|
|
import java.security.*;
|
|
import java.security.interfaces.RSAPrivateKey;
|
|
import java.security.interfaces.RSAPublicKey;
|
|
import java.security.spec.PKCS8EncodedKeySpec;
|
|
import java.security.spec.X509EncodedKeySpec;
|
|
import java.util.ArrayList;
|
|
import java.util.HashMap;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
|
|
/**
|
|
* RSA加密解密
|
|
**/
|
|
public class AuthRsaUtils {
|
|
|
|
// Rsa 私钥
|
|
public static String privateKey = "MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAMwgEvQL6w3ahkRoKxxzyBoSNe/zsX8aCaXhdyMWZZrDzFDS9/AbNjrB0bp5MwtbQVXcZJLGzaWxUmeuOQc0CeoWgwafdEdweesiUCbj4Au3xLitDVMiCrO5qy5XKRSQa6dMNjMARw5tORnvRlOiPypDBEKSyR+BtQiLDhelepLZAgMBAAECgYBO9nleft3G1inqfIFw2DkoHLNQx2x6RpBE4xs7L4bOf7+h5HqVH3Gy+Rcwk4HzerGjjUY6oT0cQ6QlB3h4GOFcQq/fN79eOKd8KwgPq+e0l/dFXDI4TAJJ61nY40zwl/KlzdRRKF4KIrM8YmA74YhjG92p6KyxBdx8QMM7NkshIQJBAP+5AXa35n/9aoENfCGr5IDoCIqOUoaOEoNGQ+DcvEW2Z443gHZ6B4QLZcMhtvn+7YQHXXjUhAw4A23dIG83ZvsCQQDMWL5lvbETU6iXhhfbF08LHqI0g83QIYckvt1ndMcTgDKR3b+T6CUJCI2VHR3kOrJ77jcIHd65nP0QRXG+ZdU7AkEAnYml4zNL5xGBaVubW0sADIHlsSYYpRglQ4YoDwEtY20Jws1icJqgwrIa0OmWRdDNFgdLiEKzzqs7QZV2g82HvQJAZLgA8Ei09J+xYy3WqEguz35D2Lp2QPWllLj2i72FOdlgE4FGofIz/uXWUv7M8ubzfh4FxdxjIP19xf1UeNHcbQJBAN53AtJB671xNU+4WBfC/hX/L45Y+kc2zkxFXDFopdbIXzoVoC2pA9urze2B8+azWWTPfqv6i620SSflHEvls2Q=";
|
|
|
|
// Rsa 公钥
|
|
public static String publicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDMIBL0C+sN2oZEaCscc8gaEjXv87F/Ggml4XcjFmWaw8xQ0vfwGzY6wdG6eTMLW0FV3GSSxs2lsVJnrjkHNAnqFoMGn3RHcHnrIlAm4+ALt8S4rQ1TIgqzuasuVykUkGunTDYzAEcObTkZ70ZToj8qQwRCkskfgbUIiw4XpXqS2QIDAQAB";
|
|
|
|
/**
|
|
* 私钥解密
|
|
*
|
|
* @param text 待解密的文本
|
|
* @return 解密后的文本
|
|
*/
|
|
public static String decryptByPrivateKey(String text) throws Exception {
|
|
return decryptByPrivateKey(privateKey, text);
|
|
}
|
|
|
|
/**
|
|
* 公钥解密
|
|
*
|
|
* @param publicKeyString 公钥
|
|
* @param text 待解密的信息
|
|
* @return 解密后的文本
|
|
*/
|
|
public static String decryptByPublicKey(String publicKeyString, String text) throws Exception {
|
|
X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(Base64.decodeBase64(publicKeyString));
|
|
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
|
|
PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec);
|
|
Cipher cipher = Cipher.getInstance("RSA");
|
|
cipher.init(Cipher.DECRYPT_MODE, publicKey);
|
|
byte[] result = cipher.doFinal(Base64.decodeBase64(text));
|
|
return new String(result);
|
|
}
|
|
|
|
/**
|
|
* 私钥加密
|
|
*
|
|
* @param privateKeyString 私钥
|
|
* @param text 待加密的信息
|
|
* @return 加密后的文本
|
|
*/
|
|
public static String encryptByPrivateKey(String privateKeyString, String text) throws Exception {
|
|
PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyString));
|
|
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
|
|
PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);
|
|
Cipher cipher = Cipher.getInstance("RSA");
|
|
cipher.init(Cipher.ENCRYPT_MODE, privateKey);
|
|
byte[] result = cipher.doFinal(text.getBytes());
|
|
return Base64.encodeBase64String(result);
|
|
}
|
|
|
|
/**
|
|
* 私钥解密
|
|
*
|
|
* @param privateKeyString 私钥
|
|
* @param text 待解密的文本
|
|
* @return 解密后的文本
|
|
*/
|
|
public static String decryptByPrivateKey(String privateKeyString, String text) throws Exception {
|
|
PKCS8EncodedKeySpec pkcs8EncodedKeySpec5 = new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyString));
|
|
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
|
|
PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec5);
|
|
Cipher cipher = Cipher.getInstance("RSA");
|
|
cipher.init(Cipher.DECRYPT_MODE, privateKey);
|
|
byte[] result = cipher.doFinal(Base64.decodeBase64(text));
|
|
return new String(result);
|
|
}
|
|
|
|
/**
|
|
* 公钥加密
|
|
*
|
|
* @param publicKeyString 公钥
|
|
* @param text 待加密的文本
|
|
* @return 加密后的文本
|
|
*/
|
|
public static String encryptByPublicKey(String publicKeyString, String text) throws Exception {
|
|
X509EncodedKeySpec x509EncodedKeySpec2 = new X509EncodedKeySpec(Base64.decodeBase64(publicKeyString));
|
|
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
|
|
PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec2);
|
|
Cipher cipher = Cipher.getInstance("RSA");
|
|
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
|
|
byte[] result = cipher.doFinal(text.getBytes());
|
|
return Base64.encodeBase64String(result);
|
|
}
|
|
|
|
/**
|
|
* 构建RSA密钥对
|
|
*
|
|
* @return 生成后的公私钥信息
|
|
*/
|
|
public static RsaKeyPair generateKeyPair() throws NoSuchAlgorithmException {
|
|
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
|
|
keyPairGenerator.initialize(1024);
|
|
KeyPair keyPair = keyPairGenerator.generateKeyPair();
|
|
RSAPublicKey rsaPublicKey = (RSAPublicKey) keyPair.getPublic();
|
|
RSAPrivateKey rsaPrivateKey = (RSAPrivateKey) keyPair.getPrivate();
|
|
String publicKeyString = Base64.encodeBase64String(rsaPublicKey.getEncoded());
|
|
String privateKeyString = Base64.encodeBase64String(rsaPrivateKey.getEncoded());
|
|
return new RsaKeyPair(publicKeyString, privateKeyString);
|
|
}
|
|
|
|
/**
|
|
* RSA密钥对对象
|
|
*/
|
|
public static class RsaKeyPair {
|
|
private final String publicKey;
|
|
private final String privateKey;
|
|
|
|
public RsaKeyPair(String publicKey, String privateKey) {
|
|
this.publicKey = publicKey;
|
|
this.privateKey = privateKey;
|
|
}
|
|
|
|
public String getPublicKey() {
|
|
return publicKey;
|
|
}
|
|
|
|
public String getPrivateKey() {
|
|
return privateKey;
|
|
}
|
|
}
|
|
|
|
public static void main(String[] args) {
|
|
// try {
|
|
// RsaKeyPair rsaKeyPair = generateKeyPair();
|
|
// System.out.println("私钥:" + rsaKeyPair.getPrivateKey());
|
|
// System.out.println("公钥:" + rsaKeyPair.getPublicKey());
|
|
// } catch (NoSuchAlgorithmException e) {
|
|
// throw new RuntimeException(e);
|
|
// }
|
|
|
|
try {
|
|
//String timestamp = String.valueOf(System.currentTimeMillis());
|
|
String timestamp = "1705165273935";
|
|
//String str = "jhcf170515993052073qrDFKJmk001" + timestamp;
|
|
|
|
// Map<String,Object> map = new HashMap<>();
|
|
// map.put("serverid","123");
|
|
// map.put("companyName","测试名称");
|
|
// String str = JSON.toJSONString(map);
|
|
|
|
List<Object> list = new ArrayList<>();
|
|
Map<String,Object> map1 = new HashMap<>();
|
|
map1.put("serverid","1231");
|
|
map1.put("companyName","测试名称1");
|
|
list.add(map1);
|
|
Map<String,Object> map2 = new HashMap<>();
|
|
map2.put("serverid","1232");
|
|
map2.put("companyName","测试名称2");
|
|
list.add(map2);
|
|
Map<String,Object> map3 = new HashMap<>();
|
|
map3.put("serverid","1233");
|
|
map3.put("companyName","测试名称3");
|
|
list.add(map3);
|
|
Map<String,Object> map4 = new HashMap<>();
|
|
map4.put("serverid","1234");
|
|
map4.put("companyName","测试名称4");
|
|
list.add(map4);
|
|
String str = JSON.toJSONString(list);
|
|
System.out.println("明文信息:" + str);
|
|
str = Md5Utils.hash(str)+timestamp;
|
|
// 公钥加密->私钥解密
|
|
String encryptByPublicKeyStr = encryptByPublicKey(publicKey, str);
|
|
System.out.println("公钥加密:" + encryptByPublicKeyStr);
|
|
String decryptByPrivateKeyStr = decryptByPrivateKey(privateKey, encryptByPublicKeyStr);
|
|
System.out.println("私钥解密:" + decryptByPrivateKeyStr);
|
|
|
|
System.out.println("***********************************");
|
|
|
|
// 私钥加密->公钥解密
|
|
String encryptByPrivateKeyStr = encryptByPrivateKey(privateKey, str);
|
|
System.out.println("私钥加密:" + encryptByPrivateKeyStr);
|
|
String decryptByPublicKeyStr = decryptByPublicKey(publicKey, encryptByPrivateKeyStr);
|
|
System.out.println("公钥解密:" + decryptByPublicKeyStr);
|
|
} catch (Exception e) {
|
|
throw new RuntimeException(e);
|
|
}
|
|
|
|
|
|
}
|
|
|
|
}
|