chenjiahe
2022-03-31 f96f3900e2ec516e10fa9143f60e7e64e500d2a0
src/main/java/com/hx/util/rsa/RSASignature.java
@@ -1,11 +1,13 @@
package com.hx.util.rsa;
import com.hx.util.StringUtils;
import java.security.KeyFactory;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.*;
/**
@@ -25,7 +27,7 @@
     * @param encode 字符集编码
     * @return 签名值
     */
    public static String sign(String content, String privateKey, String encode) {
    public static String createSign(String content, String privateKey, String encode) {
        try {
            PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec( Base64.decode(privateKey) );
@@ -49,7 +51,7 @@
        return null;
    }
    public static String sign(String content, String privateKey) {
    public static String createSign(String content, String privateKey) {
        try{
            PKCS8EncodedKeySpec priPKCS8    = new PKCS8EncodedKeySpec( Base64.decode(privateKey) );
            KeyFactory keyf = KeyFactory.getInstance("RSA");
@@ -65,6 +67,44 @@
        return null;
    }
    /**
     * RSA验签名检查
     * @param params 所有参数
     * @param publicKey 分配给开发商公钥
     * @param encode 字符集编码
     * @return 布尔值
     */
    public static boolean doCheck(Map<String,String> params, String publicKey, String encode) {
        String sign = params.get("sign");
        if(sign == null){
            return false;
        }
        String content = getSignCheckContent(params);
        return doCheck( content, sign, publicKey, encode);
    }
    public static String getSignCheckContent(Map<String, String> params) {
        if (params == null) {
            return null;
        } else {
            params.remove("sign");
            StringBuilder content = new StringBuilder();
            List<String> keys = new ArrayList(params.keySet());
            Collections.sort(keys);
            for(int i = 0; i < keys.size(); ++i) {
                String key = (String)keys.get(i);
                String value = (String)params.get(key);
                if(StringUtils.isEmpty(value)){
                    continue;
                }
                content.append(i == 0 ? "" : "&").append(key).append("=").append(value);
            }
            return content.toString();
        }
    }
    /**
     * RSA验签名检查
     * @param content 待签名数据