From 22a8875b365c568790f6115ceb6acf0f49bb8c47 Mon Sep 17 00:00:00 2001 From: 啊鑫 <t2856754968@163.com> Date: 星期四, 10 四月 2025 15:43:29 +0800 Subject: [PATCH] 测试写入数据库 --- src/main/java/com/gs/xiaomi/service/SoapApiService.java | 50 ++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 36 insertions(+), 14 deletions(-) diff --git a/src/main/java/com/gs/xiaomi/service/SoapApiService.java b/src/main/java/com/gs/xiaomi/service/SoapApiService.java index 453254f..e563848 100644 --- a/src/main/java/com/gs/xiaomi/service/SoapApiService.java +++ b/src/main/java/com/gs/xiaomi/service/SoapApiService.java @@ -1,20 +1,30 @@ package com.gs.xiaomi.service; +import com.gs.xiaomi.config.DataAcquisitionConfiguration; import com.gs.xiaomi.dto.BizDocumentResult; import com.gs.xiaomi.dto.ZfmWsApiRequest; import com.gs.xiaomi.util.SoapXmlBuilder; +import com.gs.xiaomi.util.X5StringUtils; import okhttp3.*; import org.springframework.stereotype.Service; import javax.xml.bind.JAXBContext; import javax.xml.bind.Unmarshaller; import java.io.StringReader; +import java.util.concurrent.TimeUnit; @Service public class SoapApiService { - private static final OkHttpClient client = new OkHttpClient.Builder().build(); + + private final OkHttpClient client; + + public SoapApiService() { + this.client = new OkHttpClient.Builder().connectTimeout(3000, TimeUnit.SECONDS) // Set connection timeout + .readTimeout(90, TimeUnit.SECONDS) // Set read timeout + .build(); + } public BizDocumentResult callAndParse(String url, ZfmWsApiRequest request) throws Exception { String soapXml = SoapXmlBuilder.build(request); @@ -23,14 +33,19 @@ if (response.isSuccessful() && response.body() != null) { String bodyStr = response.body().string(); - String innerXml = extractCdata(bodyStr); - if (innerXml == null) throw new RuntimeException("No CDATA <document> found in response"); + String evCode = extractEvCode(bodyStr); + if (!"Y".equalsIgnoreCase(evCode)) { + throw new RuntimeException("SOAP business failed, EV_CODE: " + evCode); + } - String decodedXml = decodeXmlEntities(innerXml); + String decodedXml = decodeXmlEntities(bodyStr); + + String innerXml = extractCdata(decodedXml); + if (innerXml == null) throw new RuntimeException("No CDATA <document> found in response"); JAXBContext context = JAXBContext.newInstance(BizDocumentResult.class); Unmarshaller unmarshaller = context.createUnmarshaller(); - return (BizDocumentResult) unmarshaller.unmarshal(new StringReader(decodedXml)); + return (BizDocumentResult) unmarshaller.unmarshal(new StringReader(innerXml)); } else { throw new RuntimeException("SOAP request failed: " + response.code() + " - " + response.message()); } @@ -40,26 +55,26 @@ MediaType mediaType = MediaType.parse("application/xml"); RequestBody body = RequestBody.create(mediaType, soapXml); + String s = DataAcquisitionConfiguration.USER_NAME + ":" + DataAcquisitionConfiguration.PWD; + String auth = X5StringUtils.encodeBase64(s); + Request request = new Request.Builder() .url(url) .method("POST", body) -// .addHeader("User-Agent", "Apifox/1.0.0 (https://apifox.com)") .addHeader("Content-Type", "application/xml") - .addHeader("Authorization", "Basic UkZDWkpYSUFPQlU6cHBCOVIhSGU=") + .addHeader("Authorization", "Basic " + auth) .addHeader("Accept", "*/*") - .addHeader("Host", "mipoq.p.mi.com") .addHeader("Connection", "keep-alive") -// .addHeader("Cookie", "saplb_*=(J2EE4281420)4281450; MYSAPSSO2=AjExMDAgABJwb3J0YWw6UkZDWkpYSUFPQlWIAAdkZWZhdWx0AQALUkZDWkpYSUFPQlUCAAMwMDADAANQT1EEAAwyMDI1MDQwOTAwMTcFAAQAAAAICgALUkZDWkpYSUFPQlX%2FAQUwggEBBgkqhkiG9w0BBwKggfMwgfACAQExCzAJBgUrDgMCGgUAMAsGCSqGSIb3DQEHATGB0DCBzQIBATAiMB0xDDAKBgNVBAMTA1BPUTENMAsGA1UECxMESjJFRQIBADAJBgUrDgMCGgUAoF0wGAYJKoZIhvcNAQkDMQsGCSqGSIb3DQEHATAcBgkqhkiG9w0BCQUxDxcNMjUwNDA5MDAxNzU2WjAjBgkqhkiG9w0BCQQxFgQUvvJ1HSnOLckboGYaMR9Wiaem6z4wCQYHKoZIzjgEAwQvMC0CFQDKLPrpUC19VM2gcslWaHAnh7dfxQIUNs2dTxwGcKdNU%2FdAQPs4f08yaw4%3D; JSESSIONID=_6bPldDq9mFJPXEd11bc-GvrWMAVlgFqVEEA_SAPF-GrpRbcuqxMK_gShBYGdmdp; JSESSIONMARKID=QPmRVwktCDxMazp0fUbEMC40LWvmuqOMUbIGpUQQA") .build(); return client.newCall(request).execute(); } - private String extractCdata(String xml) { - int cdataStart = xml.indexOf("<![CDATA["); - int cdataEnd = xml.indexOf("]]>", cdataStart); - if (cdataStart == -1 || cdataEnd == -1) return null; - return xml.substring(cdataStart + 9, cdataEnd).trim(); + private String extractEvCode(String xml) { + int start = xml.indexOf("<EV_CODE>"); + int end = xml.indexOf("</EV_CODE>", start); + if (start == -1 || end == -1) return null; + return xml.substring(start + 9, end).trim(); } private String decodeXmlEntities(String xml) { @@ -69,4 +84,11 @@ .replace(">", ">") .replace("&", "&"); } + + private String extractCdata(String xml) { + int cdataStart = xml.indexOf("<EV_RESULT>"); + int cdataEnd = xml.indexOf("</EV_RESULT>", cdataStart); + if (cdataStart == -1 || cdataEnd == -1) return null; + return xml.substring(cdataStart + 11, cdataEnd).trim(); + } } -- Gitblit v1.9.3