From 01abd59918bfc5412e23f685997bc4a4bfdbfc50 Mon Sep 17 00:00:00 2001
From: “djh” <“3298565835@qq.com”>
Date: 星期一, 17 二月 2025 10:41:40 +0800
Subject: [PATCH] 煤矿缴费修改

---
 exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java |  191 ++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 184 insertions(+), 7 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 8c94e73..2d5d976 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;
@@ -29,6 +33,9 @@
 import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
 import org.apache.http.message.BasicNameValuePair;
 import org.apache.http.util.EntityUtils;
+import org.dom4j.Element;
+import org.dom4j.io.OutputFormat;
+import org.dom4j.io.XMLWriter;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.http.ResponseEntity;
 import org.springframework.stereotype.Component;
@@ -36,8 +43,8 @@
 import javax.net.ssl.SSLContext;
 import javax.net.ssl.TrustManager;
 import javax.net.ssl.X509TrustManager;
-import java.io.IOException;
-import java.io.UnsupportedEncodingException;
+import java.io.*;
+import java.nio.charset.StandardCharsets;
 import java.security.KeyManagementException;
 import java.security.NoSuchAlgorithmException;
 import java.security.cert.X509Certificate;
@@ -67,6 +74,12 @@
     @Value("${finance.queryUrl}")
     private String queryUrl;
 
+    @Value("${finance.uploadXmlUrl}")
+    private String uploadXmlUrl;
+
+//    @Value(("${finance.path}"))
+//    private String path;
+
     /**
      * 请求开票,发起支付
      * @param payReqData
@@ -77,21 +90,23 @@
 
         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");
+        log.info("请求地址:"+"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");
+        log.info("请求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);
+        log.info("请求结果为:"+resultVo);
         return resultVo;
     }
 
@@ -337,4 +352,166 @@
         return ResponseEntity.ok(result);
 
     }
+
+    //上传财政电子票据签名文件
+    public ResultVo uploadXml(String orderId, byte[] plain) throws IOException {
+        Map<String, String> params = new HashMap<>();
+
+//        Sign sign = new Sign();
+//        SignResult sign1 = this.sign(plain);
+//        log.info("签名结果为:"+ Arrays.toString(sign1.getSignData()));
+//        VerifyResult verify = this.verify(plain, 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);
+        jsonObject.put("fileData", Base64.getEncoder().encodeToString(plain));
+
+        String reqdata = Base64.getEncoder().encodeToString(jsonObject.toJSONString().getBytes());
+        String mac = "ED76A5F1703540BE977D34780B371FEB"+"||" +reqdata;
+        mac = DigestUtils.md5Hex(mac.getBytes());
+
+        params.put("appid","ED76A5F1703540BE977D34780B371FEB");
+        params.put("reqdata",reqdata);
+        params.put("mac",mac);
+
+        HttpPost httpPost = new HttpPost("http://finpt.xjcz.gov.cn/fs-service-test/fs-pay/uploadXml.do");
+        httpPost.setEntity(assemblyFormEntity(params,"utf-8"));
+        HttpClient httpClient = getHttpClient("http://finpt.xjcz.gov.cn/fs-service-test/fs-pay/uploadXml.do");
+        HttpResultVo execute = httpClient.execute(httpPost, getResponseHandler());
+        String stringContent = execute.getStringContent();
+        ResultVo resultVo = JSONObject.parseObject(stringContent, ResultVo.class);
+        log.info("请求结果转为:"+resultVo);
+        return resultVo;
+    }
+
+    //获取XML文件字节码
+    public static byte[] convertElementToByteArray(Element element) {
+        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
+
+        try {
+            // 设置输出格式
+            OutputFormat format = OutputFormat.createPrettyPrint();
+            format.setEncoding("UTF-8"); // 设置编码为UTF-8
+
+            // 创建 XMLWriter
+            XMLWriter writer = new XMLWriter(new OutputStreamWriter(byteArrayOutputStream, StandardCharsets.UTF_8), format);
+
+            // 写入 Element 对象
+            writer.write(element.getDocument());
+            writer.close(); // 关闭 writer,确保所有数据都被写入
+
+        } catch (IOException e) {
+            e.printStackTrace(); // 打印异常信息
+            // 处理异常,比如返回一个空的字节数组或重新抛出异常
+            return new byte[0];
+        }
+
+        // 返回字节数组
+        return byteArrayOutputStream.toByteArray();
+    }
+
+
+    //签名
+    public SignResult sign(byte[] strData) {
+        SignResult result = null;
+        String certId = "11650000MB1957293J";
+        try {
+            AdvanceSignClient client = new AdvanceSignClient("F:\\text\\cssconfig.properties");
+            result = client.sign(certId,strData);
+            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(byte[] strData,byte[] signData){
+        VerifyResult verify = null;
+        try {
+            SignClient client = new SignClient("F:\\text\\cssconfig.properties");
+            byte[] plain = strData;
+            byte[] sign = signData;
+
+            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(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;
+    }
+
+
+
+
+
+
+
+
+
 }

--
Gitblit v1.9.2