教育训练处考试制证系统后端
“djh”
2025-02-18 bc472feefdfc4afbcb0fcd35a8fb8d047edf6a9f
exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java
@@ -1,5 +1,12 @@
package com.gkhy.exam.pay.utils;
import cn.com.jit.mof.MOFClient;
import cn.com.jit.mof.bean.MOFSignResult;
import cn.com.jit.mof.bean.MOFVerifyResult;
import cn.com.jit.new_vstk.AdvanceSignClient;
import cn.com.jit.new_vstk.Bean.*;
import cn.com.jit.new_vstk.SignClient;
import cn.com.jit.new_vstk.exception.NewCSSException;
import com.alibaba.fastjson2.JSONObject;
import com.gkhy.exam.pay.entity.PayReqData;
import lombok.extern.slf4j.Slf4j;
@@ -39,10 +46,7 @@
import javax.net.ssl.SSLContext;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
@@ -76,6 +80,9 @@
    @Value("${finance.uploadXmlUrl}")
    private String uploadXmlUrl;
//    @Value(("${finance.path}"))
//    private String path;
    /**
     * 请求开票,发起支付
     * @param payReqData
@@ -85,14 +92,17 @@
    public ResultVo sendApiPost(PayReqData payReqData) throws IOException {
        Map<String, String> param = new HashMap<>();
//        String appid = "A1749891493E4CDDBFE4506357B1F0AB";
//        String orderUrl = "http://finpt.xjcz.gov.cn/fs-service/fs-pay/invoice.do";
        HttpPost httpPost = new HttpPost(orderUrl);
        log.info("请求地址:"+orderUrl);
        //请求参数转为json格式base64编码
        String reqData = Base64.getEncoder().encodeToString(JSONObject.toJSONString(payReqData).getBytes());
        String mac = appId + "||" + reqData;
        mac = DigestUtils.md5Hex(mac.getBytes());
        param.put("appid", appId);
        log.info("请求appid:"+appId);
        param.put("reqdata", reqData);
        param.put("mac", mac);
@@ -352,12 +362,12 @@
    public ResultVo uploadXml(String orderId, String plain) throws IOException {
        Map<String, String> params = new HashMap<>();
        Sign sign = new Sign();
        Element signature = sign.getSignature(plain);
//        String appid = "A1749891493E4CDDBFE4506357B1F0AB";
//        String orderUrl = "http://finpt.xjcz.gov.cn/fs-service/fs-pay/uploadXml.do";
        JSONObject jsonObject = new JSONObject();
        jsonObject.put("orderNo",orderId);
        jsonObject.put("fileData", Base64.getEncoder().encodeToString(convertElementToByteArray(signature)));
        jsonObject.put("fileData", Base64.getEncoder().encodeToString(plain.getBytes()));
        String reqdata = Base64.getEncoder().encodeToString(jsonObject.toJSONString().getBytes());
        String mac = appId+"||" +reqdata;
@@ -403,4 +413,143 @@
        return byteArrayOutputStream.toByteArray();
    }
    public JSONObject signFileV2(String fileData) throws Exception {
        JSONObject xysfResult = new JSONObject();
        String certId = "11650000MB1957293J";
        MOFSignResult result = null;
//        Map<String, Object> mmp = new HashMap<>();
        try {
            String filePath = "F:\\text\\cssconfig.properties";
            System.out.println("配置文件路径:" + filePath);
            MOFClient client = new MOFClient(filePath);
            System.out.println("证书标识为:" + certId);
            System.out.println("待签名数据:" + fileData);
            result = client.sign(certId, fileData.getBytes(StandardCharsets.UTF_8));
            System.out.println("签名返回结果:" + JSONObject.toJSONString(result));
            byte[] signData = result.getSignData();
            String base64Str = new String(Base64.getEncoder().encode(signData));
//            mmp.put("signResult", base64Str);
            MOFVerifyResult resultVer = client.verifySign(signData, fileData.getBytes(StandardCharsets.UTF_8));
            System.out.println("验签结果为:" + JSONObject.toJSONString(resultVer));
//            mmp.put("issure", resultVer.getIssure());
//            mmp.put("sn", resultVer.getSn());
//            mmp.put("signTime", resultVer.getSignTime());
            SignDto signDto = new SignDto(resultVer.getSignTime(),base64Str,resultVer.getIssure(),resultVer.getSn());
            xysfResult.put("success", Boolean.valueOf(true));
            xysfResult.put("content", signDto);
            return xysfResult;
        } catch (NewCSSException e) {
            System.out.println("****签名失败****");
            System.out.println("错误号为:" + e.getCode());
            System.out.println("错误描述为:" + e.getDescription());
            xysfResult.put("success", Boolean.valueOf(false));
            xysfResult.put("msg", "系统错误");
            return xysfResult;
        }
    }
    //签名
    public SignResult sign(String strData) {
        SignResult result = null;
        String certId = "11650000MB1957293J";
        try {
            MOFClient client = new MOFClient("F:\\text\\cssconfig.properties");
            result = client.sign(certId,strData.getBytes(StandardCharsets.UTF_8));
            log.info("***签名成功***");
            log.info("签名返回结果为:"+result);
            byte[] signData = result.getSignData();
            String s = new String(Base64.getEncoder().encode(signData));
            log.info("签名结果为:"+s);
        } catch (NewCSSException e) {
            log.info("签名失败");
            log.info("错误号为:" + e.getCode());
            log.info("错误描述为: " + e.getDescription());
            log.info("日志标识码: " + e.getSerialNumber());
        }
        return result;
    }
    /**
     * 验签名
     */
    public MOFVerifyResult verify(byte[] strData,String signData){
        MOFVerifyResult verify = null;
        try {
            MOFClient client = new MOFClient("F:\\text\\cssconfig.properties");
            verify = client.verifySign(strData, signData.getBytes(StandardCharsets.UTF_8));
            log.info("验签成功");
            log.info("    证书subjectdn: " + verify.getSubjectdn());
            log.info("    证书issuer: " + verify.getIssure());
            log.info("    证书SN: " + verify.getSn());
            log.info("    证书实体base64: " + verify.getDsCert());
        } catch (NewCSSException e) {
            log.info("****操作失败****");
            log.info("错误号为:" + e.getCode());
            log.info("错误描述为: " + e.getDescription());
            log.info("日志标识码: " + e.getSerialNumber());
        }
        return verify;
    }
    /**
     * 制作数字信封
     */
    public EnvelopResult encryptEnvelop(byte[] plain){
        EnvelopResult envelopResult = null;
        try {
            AdvanceSignClient client = new AdvanceSignClient("F:\\text\\cssconfig.properties");
            String certId = "rsa";
            CertIdParams certIdParams = new CertIdParams(certId);
            //将封装好的加密证书参数对象放入 数组中
            CertParams[] envelopCerts =  new CertIdParams[]{certIdParams};
            /* 制作信封 */
            envelopResult = client.encryptEnvelop(envelopCerts, plain);
            byte[] envelopData = envelopResult.getEnvelopData();
            log.info("信封结果:["+envelopData+"]");
        } catch (NewCSSException e) {
            throw new RuntimeException(e);
        }
        return envelopResult;
    }
    /**
     * 解密数字信封
     */
    public DecryptResult decryptEnvelop(String signData){
        DecryptResult result = null;
        try {
            AdvanceSignClient client = new AdvanceSignClient("F:\\text\\cssconfig.properties");
            byte[] enc_data = signData.getBytes();
            result = client.decryptEnvelop(enc_data);
            log.info("解密数字信封结果成功");
            String plainData = new String(result.getPlainData());
            log.info("原文:"+plainData);
            log.info("    证书subjectdn: " + result.getSubjectdn());
            log.info("    证书issuer: " + result.getIssure());
            log.info("    证书SN: " + result.getSn());
            log.info("    证书实体base64: " + result.getDsCert());
        } catch (NewCSSException e) {
            log.info("****操作失败****");
            log.info("错误号为:" + e.getCode());
            log.info("错误描述为: " + e.getDescription());
            log.info("日志标识码: " + e.getSerialNumber());
        }
        return result;
    }
}