From bc472feefdfc4afbcb0fcd35a8fb8d047edf6a9f Mon Sep 17 00:00:00 2001 From: “djh” <“3298565835@qq.com”> Date: 星期二, 18 二月 2025 16:50:30 +0800 Subject: [PATCH] 煤矿缴费修改 --- exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java | 165 ++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 157 insertions(+), 8 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..4f2e5c6 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,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; + } + + + + + + + + + } -- Gitblit v1.9.2