From 70dcf4e610a0ec5fd6ca2c3daf9edf4957b30529 Mon Sep 17 00:00:00 2001 From: “djh” <“3298565835@qq.com”> Date: 星期二, 25 二月 2025 16:34:46 +0800 Subject: [PATCH] 考试制证修改 --- exam-system/src/main/java/com/gkhy/exam/pay/utils/PayUtils.java | 324 +++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 282 insertions(+), 42 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 ab6c6e9..1a707b2 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 @@ -5,10 +5,15 @@ 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 cn.hutool.http.HttpUtil; import com.alibaba.fastjson2.JSONObject; import com.gkhy.exam.pay.entity.PayReqData; +import com.xjhys.edu.fee.sdk.client.BillClient; +import com.xjhys.edu.fee.sdk.client.impl.ClientFactory; +import com.xjhys.edu.fee.sdk.model.ResponseDataVo; +import com.xjhys.edu.fee.sdk.model.SignatureFileVo; +import com.xjhys.edu.fee.sdk.model.UploadXmlReponseDataVo; import lombok.extern.slf4j.Slf4j; import org.apache.commons.codec.digest.DigestUtils; import org.apache.http.HttpEntity; @@ -42,6 +47,7 @@ import org.springframework.beans.factory.annotation.Value; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Component; +import sun.misc.BASE64Encoder; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManager; @@ -49,6 +55,7 @@ import java.io.*; import java.nio.charset.StandardCharsets; import java.security.KeyManagementException; +import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.security.cert.X509Certificate; import java.util.*; @@ -85,6 +92,7 @@ /** * 请求开票,发起支付 + * * @param payReqData * @return * @throws IOException @@ -96,13 +104,13 @@ String orderUrl = "http://finpt.xjcz.gov.cn/fs-service/fs-pay/invoice.do"; HttpPost httpPost = new HttpPost(orderUrl); - log.info("请求地址:"+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); + log.info("请求appid:" + appid); param.put("reqdata", reqData); param.put("mac", mac); @@ -111,7 +119,7 @@ HttpResultVo execute = httpClient.execute(httpPost, getResponseHandler()); String stringContent = execute.getStringContent(); ResultVo resultVo = JSONObject.parseObject(stringContent, ResultVo.class); - log.info("请求结果为:"+resultVo); + log.info("请求结果为:" + resultVo); return resultVo; } @@ -303,7 +311,7 @@ String stringContent = execute.getStringContent(); ResultVo resultVo = JSONObject.parseObject(stringContent, ResultVo.class); log.info("请求结果为:" + resultVo); - if (resultVo.getRespcode().equals("BUS0000")) { + if (resultVo.getRespcode().equals(CaiZhengConstans.CAI_ZHENG_SUCCESS)) { return "success"; } return "fail"; @@ -338,21 +346,21 @@ Map<String, String> params = new HashMap<>(); JSONObject jsonObject = new JSONObject(); - jsonObject.put("billNo",billNO); + jsonObject.put("billNo", billNO); 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("reqdata",reqdata); - params.put("mac",mac); + params.put("appid", appId); + params.put("reqdata", reqdata); + params.put("mac", mac); HttpPost httpPost = new HttpPost(queryUrl); - httpPost.setEntity(assemblyFormEntity(params,"utf-8")); + httpPost.setEntity(assemblyFormEntity(params, "utf-8")); HttpClient httpClient = getHttpClient(queryUrl); HttpResultVo execute = httpClient.execute(httpPost, getResponseHandler()); String stringContent = execute.getStringContent(); JSONObject jsonObject1 = JSONObject.parseObject(stringContent); - log.info("请求结果转json后为:"+jsonObject1); + log.info("请求结果转json后为:" + jsonObject1); String result = (String) jsonObject1.get("reqdata"); return ResponseEntity.ok(result); @@ -373,26 +381,265 @@ String orderUrl = "http://finpt.xjcz.gov.cn/fs-service/fs-pay/uploadXml.do"; JSONObject jsonObject = new JSONObject(); - jsonObject.put("orderNo",orderId); + jsonObject.put("orderNo", orderId); 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("reqdata",reqdata); - params.put("mac",mac); + params.put("appid", appid); + params.put("reqdata", reqdata); + params.put("mac", mac); HttpPost httpPost = new HttpPost(orderUrl); - httpPost.setEntity(assemblyFormEntity(params,"utf-8")); + httpPost.setEntity(assemblyFormEntity(params, "utf-8")); HttpClient httpClient = getHttpClient(orderUrl); HttpResultVo execute = httpClient.execute(httpPost, getResponseHandler()); String stringContent = execute.getStringContent(); ResultVo resultVo = JSONObject.parseObject(stringContent, ResultVo.class); - log.info("请求结果转为:"+resultVo); + log.info("请求结果转为:" + resultVo); return resultVo; } + + + public ResultVo faqiV2(PayReqData payReqData) { + System.out.println("发起接到参数===" + payReqData.toString()); + + String reqdatastr = JSONObject.toJSONString(payReqData); + + String mac = this.getMD5(appId+"||"+ this.getBase64(payReqData)); + JSONObject jsonObject = new JSONObject(); + jsonObject.put("appid", appId); + jsonObject.put("mac", mac); + jsonObject.put("reqdata", this.getBase64(payReqData)); + Map<String, String> header = new HashMap(); + header.put("Accept", "application/json;charset=utf-8"); + header.put("Content-Type", "application/json;charset=utf-8"); + String resultStr = HttpUtil.post(orderUrl, jsonObject); + System.out.println("发起入参===" + jsonObject); + JSONObject result = JSONObject.parseObject(resultStr); + ResultVo resultVo = JSONObject.parseObject(resultStr, ResultVo.class); + System.out.println("发起回参===" + result); + result.put("postData", reqdatastr); + JSONObject jsonObject2 = result.getJSONObject("respdata"); + String signfile = jsonObject2.getString("fileData"); + String orderNo1 = jsonObject2.getString("orderNo"); + // /home/www/swspkmas/files/ +// String xmlFilePath = "/home/www/swspkmas/files/" + orderNo1 + ".xml"; + String xmlFilePath = "F:\\text\\" + orderNo1 + ".xml"; + generateBase64StringToFile(signfile, xmlFilePath); + String trr2 = ""; + + try { + File file = new File(xmlFilePath); + FileReader reader1 = new FileReader(file); + BufferedReader bReader = new BufferedReader(reader1); + StringBuilder sb = new StringBuilder(); + String s = ""; + + while ((s = bReader.readLine()) != null) { + sb.append(s); + } + + bReader.close(); + trr2 = sb.toString(); + } catch (Exception var34) { + Exception e = var34; + e.printStackTrace(); + } + + String jmsignfile = this.signFilejdnew(trr2); + String zuizhongpath = montageXmlV3(xmlFilePath, jmsignfile); + String zzsignfile = convertFileToBase64(zuizhongpath); + Boolean b = this.uploadXmlV2(orderNo1, zzsignfile); + + File file = new File(xmlFilePath); + file.delete(); + File file1 = new File(zuizhongpath); + file1.delete(); + if (b) { + return resultVo; + } else { + resultVo.setRespcode("BUS8888"); + } + return resultVo; + } + + public static String montageXmlV3(String ywfilePath, String xmlStr) { + try { + String outputxmlpath = ywfilePath.replace(".xml", "_3.xml"); + xmlStr = xmlStr.trim().replace("\n", ""); + FileWriter writer = new FileWriter(outputxmlpath); + writer.write(xmlStr); + writer.close(); + return outputxmlpath; + } catch (Exception var4) { + Exception e = var4; + e.printStackTrace(); + return null; + } + } + + public static String convertFileToBase64(String imgPath) { + byte[] data = null; + + try { + InputStream in = new FileInputStream(imgPath); + data = new byte[((InputStream) in).available()]; + ((InputStream) in).read(data); + ((InputStream) in).close(); + } catch (IOException var4) { + IOException e = var4; + e.printStackTrace(); + } + + BASE64Encoder encoder = new BASE64Encoder(); + String base64Str = encoder.encode(data); + return base64Str; + } + + public static boolean generateBase64StringToFile(String fileStr, String fileFilePath) { + if (fileStr == null) { + return false; + } else { + try { + byte[] b = org.apache.commons.codec.binary.Base64.decodeBase64(fileStr); + + for (int i = 0; i < b.length; ++i) { + if (b[i] < 0) { + b[i] = (byte) (b[i] + 256); + } + } + + OutputStream out = new FileOutputStream(fileFilePath); + ((OutputStream) out).write(b); + ((OutputStream) out).flush(); + ((OutputStream) out).close(); + return true; + } catch (Exception var4) { + return false; + } + } + } + + public String signFilejdnew(String plain) { + BillSign sign = new BillSign(new ISignCommond() { + @Override + public SignDto signSm3Detach(String plain) { + SignDto dto = null; + + try { + JSONObject jsonObject = new JSONObject(); + jsonObject.put("data", plain); + JSONObject Result = signFileV2(jsonObject); + dto = new SignDto(Result.getJSONObject("content").getDate("signTime"), Result.getJSONObject("content").getString("signResult"), "CN=Private Certificate Authority Of MOF SM2,O=MOF,C=CN", "142FA2FA197E349C"); + } catch (Exception var5) { + Exception exception = var5; + exception.printStackTrace(); + } + + return dto; + } + }); + + try { + String xx = sign.signBill(plain); + return xx; + } catch (Exception var4) { + var4.printStackTrace(); + return null; + } + } + + + public JSONObject signFileV2(JSONObject job) throws Exception { + JSONObject xysfResult = new JSONObject(); + String certId = "11650000MB1957293J"; + String plain = job.getString("data").trim(); + 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("待签名数据:" + plain); + result = client.sign(certId, plain.getBytes(StandardCharsets.UTF_8)); + System.out.println("签名返回结果:" + JSONObject.toJSONString(result)); + byte[] signData = result.getSignData(); + String base64Str = new String(cn.com.jit.ida.util.pki.encoders.Base64.encode(signData)); + mmp.put("signResult", base64Str); + MOFVerifyResult resultVer = client.verifySign(signData, plain.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()); + xysfResult.put("success", true); + xysfResult.put("content", mmp); + return xysfResult; + } catch (NewCSSException var12) { + NewCSSException e = var12; + System.out.println("****签名失败****"); + System.out.println("错误号为:" + e.getCode()); + System.out.println("错误描述为:" + e.getDescription()); + xysfResult.put("success", false); + xysfResult.put("msg", "系统错误"); + return xysfResult; + } + } + + public Boolean uploadXmlV2(String orderNo, String signFile) { + log.info("上传验签开始"); + log.info("上传验签参数订单号:" + orderNo + "签名文件:" + signFile); + ResponseDataVo<?> res = ClientFactory.sdkConfig(appId, "http://finpt.xjcz.gov.cn/fs-service", "http://finpt.xjcz.gov.cn/fs-service"); + SignatureFileVo signatureFile = new SignatureFileVo(); + signatureFile.setFileData(signFile); + signatureFile.setOrderNo(orderNo); + BillClient billClient = ClientFactory.getBillClient(); + ResponseDataVo<UploadXmlReponseDataVo> dataRes = billClient.uploadXml(signatureFile); + + if (!dataRes.getRespcode().equals(CaiZhengConstans.CAI_ZHENG_SUCCESS)) { + log.info("上传验签失败:" + dataRes); + return false; + } +// String mac = this.getMD5("A1749891493E4CDDBFE4506357B1F0AB||" + this.getBase64(signatureFile.toString())); +// JSONObject jsonObject = new JSONObject(); +// jsonObject.put("appid", "A1749891493E4CDDBFE4506357B1F0AB"); +// jsonObject.put("mac", mac); +// jsonObject.put("reqdata", this.getBase64(signatureFile.toString())); + return true; + } + + public String getMD5(String input) { + try { + MessageDigest md = MessageDigest.getInstance("MD5"); + byte[] messageDigest = md.digest(input.getBytes()); + StringBuilder hexString = new StringBuilder(); + byte[] var5 = messageDigest; + int var6 = messageDigest.length; + + for (int var7 = 0; var7 < var6; ++var7) { + byte b = var5[var7]; + hexString.append(String.format("%02x", b)); + } + + return hexString.toString(); + } catch (NoSuchAlgorithmException var9) { + NoSuchAlgorithmException e = var9; + throw new RuntimeException(e); + } + } + + public String getBase64(PayReqData str) { +// String encodedStr = org.apache.commons.codec.binary.Base64.encodeBase64String(str.getBytes()); + String reqData = Base64.getEncoder().encodeToString(JSONObject.toJSONString(str).getBytes()); + + return reqData; + + } + //获取XML文件字节码 public static byte[] convertElementToByteArray(Element element) { @@ -428,7 +675,8 @@ // Map<String, Object> mmp = new HashMap<>(); try { - String filePath = "F:\\text\\cssconfig.properties"; +// String filePath = "/home/www/swspkmas/cssconfig.properties"; + String filePath = "F:\\text/cssconfig.properties"; System.out.println("配置文件路径:" + filePath); MOFClient client = new MOFClient(filePath); System.out.println("证书标识为:" + certId); @@ -443,7 +691,7 @@ // 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()); + SignDto signDto = new SignDto(resultVer.getSignTime(), base64Str, resultVer.getIssure(), resultVer.getSn()); xysfResult.put("success", Boolean.valueOf(true)); xysfResult.put("content", signDto); return xysfResult; @@ -458,19 +706,18 @@ } - //签名 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)); + MOFClient client = new MOFClient("/home/www/swspkmas/cssconfig.properties"); + result = client.sign(certId, strData.getBytes(StandardCharsets.UTF_8)); log.info("***签名成功***"); - log.info("签名返回结果为:"+result); + log.info("签名返回结果为:" + result); byte[] signData = result.getSignData(); String s = new String(Base64.getEncoder().encode(signData)); - log.info("签名结果为:"+s); + log.info("签名结果为:" + s); } catch (NewCSSException e) { log.info("签名失败"); log.info("错误号为:" + e.getCode()); @@ -483,10 +730,10 @@ /** * 验签名 */ - public MOFVerifyResult verify(byte[] strData,String signData){ + public MOFVerifyResult verify(byte[] strData, String signData) { MOFVerifyResult verify = null; try { - MOFClient client = new MOFClient("F:\\text\\cssconfig.properties"); + MOFClient client = new MOFClient("/home/www/swspkmas/cssconfig.properties"); verify = client.verifySign(strData, signData.getBytes(StandardCharsets.UTF_8)); log.info("验签成功"); @@ -507,18 +754,18 @@ /** * 制作数字信封 */ - public EnvelopResult encryptEnvelop(byte[] plain){ + public EnvelopResult encryptEnvelop(byte[] plain) { EnvelopResult envelopResult = null; try { - AdvanceSignClient client = new AdvanceSignClient("F:\\text\\cssconfig.properties"); + AdvanceSignClient client = new AdvanceSignClient("/home/www/swspkmas/cssconfig.properties"); String certId = "rsa"; CertIdParams certIdParams = new CertIdParams(certId); //将封装好的加密证书参数对象放入 数组中 - CertParams[] envelopCerts = new CertIdParams[]{certIdParams}; + CertParams[] envelopCerts = new CertIdParams[]{certIdParams}; /* 制作信封 */ envelopResult = client.encryptEnvelop(envelopCerts, plain); byte[] envelopData = envelopResult.getEnvelopData(); - log.info("信封结果:["+envelopData+"]"); + log.info("信封结果:[" + envelopData + "]"); } catch (NewCSSException e) { throw new RuntimeException(e); } @@ -528,15 +775,15 @@ /** * 解密数字信封 */ - public DecryptResult decryptEnvelop(String signData){ + public DecryptResult decryptEnvelop(String signData) { DecryptResult result = null; try { - AdvanceSignClient client = new AdvanceSignClient("F:\\text\\cssconfig.properties"); + AdvanceSignClient client = new AdvanceSignClient("/home/www/swspkmas/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("原文:" + plainData); log.info(" 证书subjectdn: " + result.getSubjectdn()); log.info(" 证书issuer: " + result.getIssure()); log.info(" 证书SN: " + result.getSn()); @@ -550,13 +797,6 @@ } return result; } - - - - - - - } -- Gitblit v1.9.2