From 63bd0c28d62e905f5e2b61ed344013f03d4046da Mon Sep 17 00:00:00 2001
From: “djh” <“3298565835@qq.com”>
Date: 星期三, 12 二月 2025 16:05:56 +0800
Subject: [PATCH] 煤矿缴费修改

---
 exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java |  121 ++++++++++++++++++++++++++++++++++++++-
 exam-system/src/test/java/TextPay.java                          |   56 ++++++++++++++----
 2 files changed, 160 insertions(+), 17 deletions(-)

diff --git a/exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java b/exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java
index a9038c0..f96042f 100644
--- a/exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java
+++ b/exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java
@@ -1,5 +1,9 @@
 package com.gkhy.exam.pay.utils;
 
+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;
@@ -86,18 +90,18 @@
 
         Map<String, String> param = new HashMap<>();
 
-        HttpPost httpPost = new HttpPost(orderUrl);
+        HttpPost httpPost = new HttpPost("http://finpt.xjcz.gov.cn/fs-service-test/fs-pay/invoice.do");
 
         //请求参数转为json格式base64编码
         String reqData = Base64.getEncoder().encodeToString(JSONObject.toJSONString(payReqData).getBytes());
-        String mac = appId + "||" + reqData;
+        String mac = "ED76A5F1703540BE977D34780B371FEB" + "||" + reqData;
         mac = DigestUtils.md5Hex(mac.getBytes());
-        param.put("appid", appId);
+        param.put("appid", "ED76A5F1703540BE977D34780B371FEB");
         param.put("reqdata", reqData);
         param.put("mac", mac);
 
         httpPost.setEntity(assemblyFormEntity(param, "utf-8"));
-        HttpClient httpClient = getHttpClient(orderUrl);
+        HttpClient httpClient = getHttpClient("http://finpt.xjcz.gov.cn/fs-service-test/fs-pay/invoice.do");
         HttpResultVo execute = httpClient.execute(httpPost, getResponseHandler());
         String stringContent = execute.getStringContent();
         ResultVo resultVo = JSONObject.parseObject(stringContent, ResultVo.class);
@@ -353,7 +357,11 @@
         Map<String, String> params = new HashMap<>();
 
         Sign sign = new Sign();
-        Element signature = sign.getSignature(plain);
+        SignResult sign1 = this.sign(plain);
+        log.info("签名结果为:"+ Arrays.toString(sign1.getSignData()));
+        VerifyResult verify = this.verify(plain, new String(sign1.getSignData()));
+        SignDto signDto = new SignDto("SM3", "Base64", new Date(), verify.getReturnData(), verify.getSerialNumber(), verify.getIssure());
+        Element signature = sign.getSignature(signDto);
 
         JSONObject jsonObject = new JSONObject();
         jsonObject.put("orderNo",orderId);
@@ -403,4 +411,107 @@
         return byteArrayOutputStream.toByteArray();
     }
 
+
+    //签名
+    public SignResult sign(String strData) {
+        SignResult result = null;
+        String certId = "rsa";
+        try {
+            AdvanceSignClient client = new AdvanceSignClient("cssconfig.properties");
+            result = client.sign(certId,strData.getBytes());
+            log.info("***签名成功***");
+            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 VerifyResult verify(String strData,String signData){
+        VerifyResult verify = null;
+        try {
+            AdvanceSignClient client = new AdvanceSignClient("cssconfig.properties");
+            byte[] plain = strData.getBytes();
+            byte[] sign = signData.getBytes();
+
+            verify = client.verify(sign, plain);
+            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(String plain){
+        EnvelopResult envelopResult = null;
+        try {
+            AdvanceSignClient client = new AdvanceSignClient("cssconfig.properties");
+            String certId = "rsa";
+            CertIdParams certIdParams = new CertIdParams(certId);
+            //将封装好的加密证书参数对象放入 数组中
+            CertParams[] envelopCerts =  new CertIdParams[]{certIdParams};
+            byte[] bytes = plain.getBytes();
+            /* 制作信封 */
+            envelopResult = client.encryptEnvelop(envelopCerts, bytes);
+            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("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;
+    }
+
+
+
+
+
+
+
+
+
 }
diff --git a/exam-system/src/test/java/TextPay.java b/exam-system/src/test/java/TextPay.java
index 3d46294..aa71763 100644
--- a/exam-system/src/test/java/TextPay.java
+++ b/exam-system/src/test/java/TextPay.java
@@ -1,8 +1,14 @@
+import cn.com.jit.new_vstk.Bean.EnvelopResult;
+import cn.com.jit.new_vstk.Bean.SignResult;
+import cn.com.jit.new_vstk.Bean.VerifyResult;
 import com.gkhy.exam.pay.entity.PayReqData;
 import com.gkhy.exam.pay.utils.PayUtils;
 import com.gkhy.exam.pay.utils.ResultVo;
+import com.gkhy.exam.pay.utils.Sign;
+import com.gkhy.exam.pay.utils.SignDto;
 import com.ruoyi.common.utils.RandomUtil;
 import lombok.extern.log4j.Log4j2;
+import org.dom4j.Element;
 import org.junit.jupiter.api.Test;
 import org.springframework.boot.test.context.SpringBootTest;
 import org.springframework.test.context.ActiveProfiles;
@@ -10,6 +16,8 @@
 import java.io.IOException;
 import java.math.BigDecimal;
 import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Date;
 import java.util.List;
 
 @SpringBootTest(classes = TextPay.class)
@@ -25,21 +33,36 @@
         PayReqData payReqData = new PayReqData();
         PayReqData.Feedata feedatas = new PayReqData.Feedata();
 
-        payReqData.setDesc("安全技术考试考务费_煤矿安全作业-001504");
-        payReqData.setOrderNo(RandomUtil.generateOrderNumber(1L, "CO"));
-        payReqData.setMoney(BigDecimal.valueOf(103));
-        payReqData.setAmount(1);
-        payReqData.setPayerName("测试");
-        payReqData.setCertNo("411381199801093991");
-        payReqData.setPayerType(1);
-        payReqData.setInvoiceSocialCode("11650000MB1957293J");
-        payReqData.setHandlingPerson("张三");
-        payReqData.setChecker("李四");
-        payReqData.setEnterCode("680534083");
 
+        //订单编号
+        payReqData.setOrderNo(RandomUtil.generateOrderNumber(1L, "CO"));
+        //订单总金额
+        payReqData.setMoney(BigDecimal.valueOf(103));
+        //子订单数目
+        payReqData.setAmount(1);
+        //缴费人姓名(单位填单位名称)
+        payReqData.setPayerName("新疆维吾尔自治区应急管理宣传教育中心");
+        //缴费人证件号(单位填同一信用代码)
+        payReqData.setCertNo("65000023000000172848");
+        //缴款人类型(1个人  2单位)
+        payReqData.setPayerType(2);
+        //开票单位社会信用代码
+        payReqData.setInvoiceSocialCode("65000023000000172848");
+        //开票人
+        payReqData.setHandlingPerson("张三");
+        //复核人
+        payReqData.setChecker("李四");
+        //单位编码
+        payReqData.setEnterCode("680534083");
+        //订单描述(非必填)
+        payReqData.setDesc("安全技术考试考务费_煤矿安全作业-001504");
+        //订单明细
         List<PayReqData.Feedata> feedatas1 = new ArrayList<>();
+        //数量
         feedatas.setAmount(1);
+        //业务代码
         feedatas.setBusCode("DZ001504");
+        //单价
         feedatas.setPrice(BigDecimal.valueOf(103));
         feedatas1.add(feedatas);
         payReqData.setFeeDatas(feedatas1);
@@ -47,7 +70,16 @@
 
         PayUtils payUtils = new PayUtils();
         ResultVo resultVo = payUtils.sendApiPost(payReqData);
-        System.out.printf("请求结果:" + resultVo);
+//        log.info("请求结果:" + resultVo);
+//        String fileData = resultVo.getRespdata().getFileData();
+//        SignResult sign = payUtils.sign(fileData);
+//        log.info("签名结果为:"+ Arrays.toString(sign.getSignData()));
+//        VerifyResult verify = payUtils.verify(fileData, new String(sign.getSignData()));
+//        SignDto signDto = new SignDto("SM3", "Base64", new Date(), verify.getReturnData(), verify.getSerialNumber(), verify.getIssure());
+//        Sign sign1 = new Sign();
+//        Element signature = sign1.getSignature(signDto);
+//        EnvelopResult envelopResult = payUtils.encryptEnvelop(String.valueOf(signature));
+//        log.info("制作数字信封为:"+ Arrays.toString(envelopResult.getEnvelopData()));
 
     }
 

--
Gitblit v1.9.2