From a8d43c9cd831282dd23214c4f9ff27c6d05d6613 Mon Sep 17 00:00:00 2001
From: peternameyakj <908253177@qq.com>
Date: Mon, 15 Jul 2024 16:52:53 +0800
Subject: [PATCH] 最大代理等级的配置
---
src/main/java/com/nq/service/impl/StockConfigServicesImpl.java | 66 ++++++++++++++++++++++++++++++++
1 files changed, 65 insertions(+), 1 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/StockConfigServicesImpl.java b/src/main/java/com/nq/service/impl/StockConfigServicesImpl.java
index 98000f9..23af9e1 100644
--- a/src/main/java/com/nq/service/impl/StockConfigServicesImpl.java
+++ b/src/main/java/com/nq/service/impl/StockConfigServicesImpl.java
@@ -4,6 +4,7 @@
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.nq.common.ServerResponse;
import com.nq.dao.StockConfigMapper;
+import com.nq.enums.EConfigKey;
import com.nq.pojo.StockConfig;
import com.nq.service.IStockConfigServices;
import org.apache.http.util.TextUtils;
@@ -11,6 +12,10 @@
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
@Service
public class StockConfigServicesImpl implements IStockConfigServices {
@@ -19,9 +24,14 @@
StockConfigMapper stockConfigMapper;
@Override
public ServerResponse updateStockConfig(StockConfig stockConfig) {
+ if(EConfigKey.LIMIT_UP_INTERVAL.getCode().equals(stockConfig.getCKey())){
+ if(!validateRanges(stockConfig.getCValue())){
+ return ServerResponse.createByErrorMsg("格式错误");
+ }
+ }
int ref = stockConfigMapper.updateById(stockConfig);
if(ref>0){
- return ServerResponse.createBySuccess();
+ return ServerResponse.createBySuccessMsg("设置成功");
}
return ServerResponse.createByErrorMsg("设置失败");
}
@@ -42,4 +52,58 @@
queryWrapper.eq("c_key",key);
return stockConfigMapper.selectOne(queryWrapper);
}
+
+ @Override
+ public Map<String, StockConfig> queryByKeys(List<String> keys) {
+ QueryWrapper<StockConfig> queryWrapper = new QueryWrapper<>();
+ queryWrapper.in("c_key", keys);
+
+ List<StockConfig> stockConfigs = stockConfigMapper.selectList(queryWrapper);
+
+ // 构建结果的 Map
+ Map<String, StockConfig> resultMap = new HashMap<>();
+ for (StockConfig config : stockConfigs) {
+ resultMap.put(config.getCKey(), config);
+ }
+
+ return resultMap;
+ }
+
+ public boolean validateRanges(String ranges) {
+ // 分割逗号分隔的多个范围
+ String[] rangeArray = ranges.split(",");
+
+ // 遍历每个范围进行验证
+ for (String range : rangeArray) {
+ // 定义匹配数字-数字格式的正则表达式
+ String regex = "^\\d+\\.\\d+-\\d+\\.\\d+$";
+
+ // 检查输入的字符串是否符合格式
+ if (range.matches(regex)) {
+ // 进一步检查数字范围的有效性
+ String[] parts = range.split("-");
+ if (parts.length == 2) {
+ try {
+ double start = Double.parseDouble(parts[0]);
+ double end = Double.parseDouble(parts[1]);
+ // 确保start < end
+ if (!(start < end)) {
+ return false;
+ }
+ } catch (NumberFormatException e) {
+ // 如果解析失败,说明不是有效的数字格式
+ return false;
+ }
+ } else {
+ // 如果不是两部分,说明格式不正确
+ return false;
+ }
+ } else {
+ // 如果不匹配正则表达式,说明格式不正确
+ return false;
+ }
+ }
+ // 所有范围验证通过
+ return true;
+ }
}
--
Gitblit v1.9.3