-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
429132b
commit cccd3d6
Showing
6 changed files
with
98 additions
and
65 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,6 +3,10 @@ | |
|
||
# 变更日志 | ||
|
||
## v3.3.8 2023-08-06 | ||
|
||
1. 处理分页异常问题 | ||
|
||
## v3.3.7 2023-08-06 | ||
|
||
1. 优化查询逻辑 | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,63 +1,83 @@ | ||
package com.lckp.jproxy.util; | ||
|
||
import java.util.regex.Matcher; | ||
import java.util.regex.Pattern; | ||
|
||
import org.apache.commons.lang3.StringUtils; | ||
|
||
import com.lckp.jproxy.constant.ApiField; | ||
|
||
/** | ||
* <p> | ||
* xml 工具类 | ||
* </p> | ||
* | ||
* @author LuckyPuppy514 | ||
* @date 2023-03-18 | ||
*/ | ||
public class XmlUtil { | ||
XmlUtil() { | ||
} | ||
|
||
/** | ||
* | ||
* 计算 xml 中的 ApiField.INDEXER_ITEM 数量 | ||
* | ||
* @param xml | ||
* @return int | ||
*/ | ||
public static int count(String xml) { | ||
int count = 0; | ||
if (StringUtils.isBlank(xml)) { | ||
return count; | ||
} | ||
Matcher matcher = Pattern.compile("<" + ApiField.INDEXER_ITEM + ">[^<]+").matcher(xml); | ||
while (matcher.find()) { | ||
count++; | ||
} | ||
return count; | ||
} | ||
|
||
/** | ||
* | ||
* 合并 | ||
* | ||
* @param xml1 | ||
* @param xml2 | ||
* @return String | ||
*/ | ||
public static String merger(String xml1, String xml2) { | ||
int index = xml1.indexOf("<" + ApiField.INDEXER_ITEM + ">"); | ||
if (index == -1) { | ||
return xml2; | ||
} | ||
index = xml2.indexOf("<" + ApiField.INDEXER_ITEM + ">"); | ||
if (index == -1) { | ||
return xml1; | ||
} | ||
StringBuilder builder = new StringBuilder(); | ||
builder.append(xml1.substring(0, xml1.indexOf("</" + ApiField.INDEXER_CHANNEL + ">"))); | ||
builder.append(xml2.substring(xml2.indexOf("<" + ApiField.INDEXER_ITEM + ">"))); | ||
return builder.toString(); | ||
} | ||
} | ||
package com.lckp.jproxy.util; | ||
|
||
import java.util.regex.Matcher; | ||
import java.util.regex.Pattern; | ||
|
||
import org.apache.commons.lang3.StringUtils; | ||
|
||
import com.lckp.jproxy.constant.ApiField; | ||
|
||
/** | ||
* <p> | ||
* xml 工具类 | ||
* </p> | ||
* | ||
* @author LuckyPuppy514 | ||
* @date 2023-03-18 | ||
*/ | ||
public class XmlUtil { | ||
XmlUtil() { | ||
} | ||
|
||
/** | ||
* | ||
* 计算 xml 中的 ApiField.INDEXER_ITEM 数量 | ||
* | ||
* @param xml | ||
* @return int | ||
*/ | ||
public static int count(String xml) { | ||
int count = 0; | ||
if (StringUtils.isBlank(xml)) { | ||
return count; | ||
} | ||
Matcher matcher = Pattern.compile("<" + ApiField.INDEXER_ITEM + ">[^<]+").matcher(xml); | ||
while (matcher.find()) { | ||
count++; | ||
} | ||
return count; | ||
} | ||
|
||
/** | ||
* | ||
* 合并 | ||
* | ||
* @param xml1 | ||
* @param xml2 | ||
* @return String | ||
*/ | ||
public static String merger(String xml1, String xml2) { | ||
int index = xml1.indexOf("<" + ApiField.INDEXER_ITEM + ">"); | ||
if (index == -1) { | ||
return xml2; | ||
} | ||
index = xml2.indexOf("<" + ApiField.INDEXER_ITEM + ">"); | ||
if (index == -1) { | ||
return xml1; | ||
} | ||
StringBuilder builder = new StringBuilder(); | ||
builder.append(xml1.substring(0, xml1.indexOf("</" + ApiField.INDEXER_CHANNEL + ">"))); | ||
builder.append(xml2.substring(xml2.indexOf("<" + ApiField.INDEXER_ITEM + ">"))); | ||
return builder.toString(); | ||
} | ||
|
||
/** | ||
* | ||
* 移除多余结果 | ||
* | ||
* @param xml | ||
* @param limit | ||
* @return String | ||
*/ | ||
public static String remove(String xml, int limit) { | ||
int count = 0; | ||
int index = 0; | ||
String itemPrefix = "<" + ApiField.INDEXER_ITEM + ">"; | ||
String itemSuffix = "</" + ApiField.INDEXER_ITEM + ">"; | ||
while (count++ <= limit) { | ||
index = xml.indexOf(itemPrefix, index + 1); | ||
} | ||
xml = xml.substring(0, index) + xml.substring(xml.lastIndexOf(itemSuffix) + itemSuffix.length()); | ||
return xml; | ||
} | ||
} |
Large diffs are not rendered by default.
Oops, something went wrong.