From 5e84b114cba06681f96ca9e4ffe565ef7811898b Mon Sep 17 00:00:00 2001 From: 啊鑫 <t2856754968@163.com> Date: 星期三, 09 四月 2025 20:13:08 +0800 Subject: [PATCH] 接口解析的实体类确认 --- src/main/java/com/gs/xiaomi/service/SoapApiService.java | 30 +++++++++++++++++++++--------- 1 files changed, 21 insertions(+), 9 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..549ed35 100644 --- a/src/main/java/com/gs/xiaomi/service/SoapApiService.java +++ b/src/main/java/com/gs/xiaomi/service/SoapApiService.java @@ -23,10 +23,15 @@ 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(); @@ -45,7 +50,7 @@ .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 ") .addHeader("Accept", "*/*") .addHeader("Host", "mipoq.p.mi.com") .addHeader("Connection", "keep-alive") @@ -55,11 +60,11 @@ 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 +74,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