From dcf2c39ca10e6b7e91a7970cd784a5bf07a55207 Mon Sep 17 00:00:00 2001
From: heheng <heheng@123456>
Date: Tue, 18 Feb 2025 16:41:52 +0800
Subject: [PATCH] merge
---
exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java | 184 ++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 170 insertions(+), 14 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..ab6c6e9 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;
+ String mac = appid + "||" + reqData;
mac = DigestUtils.md5Hex(mac.getBytes());
- param.put("appid", appId);
+ param.put("appid", appid);
+ log.info("请求appid:"+appid);
param.put("reqdata", reqData);
param.put("mac", mac);
@@ -352,24 +362,31 @@
public ResultVo uploadXml(String orderId, String plain) throws IOException {
Map<String, String> params = new HashMap<>();
- Sign sign = new Sign();
- Element signature = sign.getSignature(plain);
+// 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);
+
+ 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;
+ String mac = appid+"||" +reqdata;
mac = DigestUtils.md5Hex(mac.getBytes());
- params.put("appid",appId);
+ params.put("appid",appid);
params.put("reqdata",reqdata);
params.put("mac",mac);
- HttpPost httpPost = new HttpPost(uploadXmlUrl);
+ HttpPost httpPost = new HttpPost(orderUrl);
httpPost.setEntity(assemblyFormEntity(params,"utf-8"));
- HttpClient httpClient = getHttpClient(uploadXmlUrl);
+ HttpClient httpClient = getHttpClient(orderUrl);
HttpResultVo execute = httpClient.execute(httpPost, getResponseHandler());
String stringContent = execute.getStringContent();
ResultVo resultVo = JSONObject.parseObject(stringContent, ResultVo.class);
@@ -403,4 +420,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