From 9dc40f3aa7df3bdd489bd750d59fec8bac741a23 Mon Sep 17 00:00:00 2001
From: peter <14100000001@qq.com>
Date: Thu, 08 Jan 2026 17:48:09 +0800
Subject: [PATCH] 修改
---
src/main/java/com/nq/service/impl/UserPositionServiceImpl.java | 57 ++++++++++++++++++++++++++++++++-------------------------
1 files changed, 32 insertions(+), 25 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
index 9fdfc76..d05dfe4 100644
--- a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
@@ -514,6 +514,12 @@
}
+ public ServerResponse fee(Integer buyNum,BigDecimal nowPrice){
+ BigDecimal buy_amt = nowPrice.multiply(new BigDecimal(buyNum.intValue()));
+ SiteSetting siteSetting = this.iSiteSettingService.getSiteSetting();
+ BigDecimal buy_fee_amt = buy_amt.multiply(siteSetting.getBuyFee()).setScale(2, 4);
+ return ServerResponse.createBySuccess(buy_fee_amt);
+ }
@Transactional
public ServerResponse pending(Integer stockId, Integer buyNum, Integer buyType, Integer lever, BigDecimal profitTarget, BigDecimal stopTarget, HttpServletRequest request) throws Exception {
@@ -524,9 +530,7 @@
/*实名认证开关开启*/
SiteProduct siteProduct = iSiteProductService.getProductSetting();
User user = this.iUserService.getCurrentRefreshUser(request);
- if (!siteProduct.getTranWithdrawDisplay()) {
- return ServerResponse.createByErrorMsg("当前交易关闭");
- }
+
if (siteProduct.getRealNameDisplay() && (StringUtils.isBlank(user.getRealName()) || StringUtils.isBlank(user.getIdCard()))) {
return ServerResponse.createByErrorMsg("挂单失败,请先实名认证");
}
@@ -559,9 +563,12 @@
boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
log.info("是否在上午交易时间 = {} 是否在下午交易时间 = {}", Boolean.valueOf(am_flag), Boolean.valueOf(pm_flag));
//TODO
-// if (!am_flag && !pm_flag) {
-// return ServerResponse.createByErrorMsg("挂单失败,不在交易时段内");
+// if (!siteProduct.getTranWithdrawDisplay()) {
+// return ServerResponse.createByErrorMsg("当前交易关闭");
// }
+ if (!am_flag && !pm_flag && siteProduct.getTranWithdrawDisplay()) {
+ return ServerResponse.createByErrorMsg("挂单失败,不在交易时段内");
+ }
if (siteProduct.getHolidayDisplay()) {
return ServerResponse.createByErrorMsg("周末或节假日不能交易!");
}
@@ -573,13 +580,13 @@
List dbPosition = findPositionByStockCodeAndTimes(siteSetting.getBuySameTimes().intValue(), stock
.getStockCode(), user.getId());
- if (dbPosition.size() >= siteSetting.getBuySameNums().intValue()) {
+ if (dbPosition.size() >= siteSetting.getBuySameNums().intValue() && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("频繁交易," + siteSetting.getBuySameTimes() + "分钟内同一股票持仓不得超过" + siteSetting
.getBuySameNums() + "条");
}
Integer transNum = findPositionNumByTimes(siteSetting.getBuyNumTimes().intValue(), user.getId());
- if (transNum.intValue() / 100 >= siteSetting.getBuyNumLots().intValue()) {
+ if (transNum.intValue() / 100 >= siteSetting.getBuyNumLots().intValue() && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("频繁交易," + siteSetting
.getBuyNumTimes() + "分钟内不能超过" + siteSetting.getBuyNumLots() + "手");
}
@@ -628,20 +635,20 @@
log.info("当前涨跌幅 = {} % , 涨停幅度 = {} %", Double.valueOf(stock_crease), ztRate);
if ((new BigDecimal(String.valueOf(stock_crease))).compareTo(ztRate) == 0 && buyType
- .intValue() == 0) {
+ .intValue() == 0 && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("当前股票已涨停不能买涨");
}
if (stock.getStockPlate() == null || StringUtils.isEmpty(stock.getStockPlate())) {
int maxcrease = siteSetting.getCreaseMaxPercent().intValue();
if (stock_crease > 0.0D &&
- stock_crease >= maxcrease) {
+ stock_crease >= maxcrease && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("挂单失败,股票当前涨幅:" + stock_crease + ",大于最大涨幅:" + maxcrease);
}
if (stock_crease < 0.0D &&
- -stock_crease > maxcrease) {
+ -stock_crease > maxcrease && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("挂单失败,股票当前跌幅:" + stock_crease + ",大于最大跌幅:" + maxcrease);
}
@@ -650,26 +657,26 @@
int maxcrease = siteSetting.getCyCreaseMaxPercent().intValue();
if (stock_crease > 0.0D &&
- stock_crease >= maxcrease) {
+ stock_crease >= maxcrease && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("挂单失败,创业股当前涨幅:" + stock_crease + ",大于最大涨幅:" + maxcrease);
}
if (stock_crease < 0.0D &&
- -stock_crease > maxcrease) {
+ -stock_crease > maxcrease && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("挂单失败,创业股当前跌幅:" + stock_crease + ",大于最大跌幅:" + maxcrease);
}
} else {
int maxcrease = siteSetting.getKcCreaseMaxPercent().intValue();
if (stock_crease > 0.0D &&
- stock_crease >= maxcrease) {
+ stock_crease >= maxcrease && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("挂单失败,科创股当前涨幅:" + stock_crease + ",大于最大涨幅:" + maxcrease);
}
if (stock_crease < 0.0D &&
- -stock_crease > maxcrease) {
+ -stock_crease > maxcrease && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("挂单失败,科创股当前跌幅:" + stock_crease + ",大于最大跌幅:" + maxcrease);
}
}
@@ -683,7 +690,7 @@
.getStockDays(), daysRate, siteSetting.getStockRate()});
if (daysRate != null &&
- siteSetting.getStockRate().compareTo(daysRate) == -1) {
+ siteSetting.getStockRate().compareTo(daysRate) == -1 && siteProduct.getTranWithdrawDisplay()) {
return serverResponse.createByErrorMsg(siteSetting.getStockDays() + "天内涨幅超过 " + siteSetting
.getStockRate() + "不能交易");
}
@@ -860,9 +867,7 @@
}
SiteProduct siteProduct = iSiteProductService.getProductSetting();
- if (!siteProduct.getTranWithdrawDisplay()) {
- return ServerResponse.createByErrorMsg("当前交易关闭");
- }
+
UserPosition userPosition = this.userPositionMapper.findPositionBySn(positionSn);
if (doType != 0) {
if (userPosition.getStockGid().contains("us")) {
@@ -897,7 +902,8 @@
boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
log.info("是否在上午交易時間 = {} 是否在下午交易時間 = {}", Boolean.valueOf(am_flag), Boolean.valueOf(pm_flag));
- if (!am_flag && !pm_flag) {
+
+ if (!am_flag && !pm_flag && siteProduct.getTranWithdrawDisplay()) {
return ServerResponse.createByErrorMsg("平仓失败,不在交易时段内");
}
}
@@ -929,7 +935,7 @@
return ServerResponse.createByErrorMsg("平仓失败,此订单已平仓");
}
- if (DateTimeUtil.isCanSellOneday(userPosition.getBuyOrderTime(), siteSetting.getCantSellTimes().intValue())) {
+ if (DateTimeUtil.isCanSellOneday(userPosition.getBuyOrderTime(), siteSetting.getCantSellTimes().intValue()) && siteProduct.getTranWithdrawDisplay()) {
// return ServerResponse.createByErrorMsg(siteSetting.getCantSellTimes() + "分鐘內不能平倉");
return ServerResponse.createByErrorMsg("当日成交不可平仓");
@@ -2492,9 +2498,9 @@
if (siteProduct.getHolidayDisplay()) {
return ServerResponse.createByErrorMsg("周末或节假日不能交易!");
}
- if (!Objects.equals(stockDz.getPassword(), password)) {
- return ServerResponse.createByErrorMsg("下单失败,密钥错误");
- }
+// if (!Objects.equals(stockDz.getPassword(), password)) {
+// return ServerResponse.createByErrorMsg("下单失败,密钥错误");
+// }
if (stockDz.getIsLock().intValue() != 0) {
return ServerResponse.createByErrorMsg("下单失败,当前股票不能交易");
@@ -2515,7 +2521,7 @@
if (num < stockDz.getStockNum().intValue()) {
return ServerResponse.createByErrorMsg("下单失败,购买数量最小为" + stockDz.getStockNum() + "股");
}
- if (num > stockDz.getStockSurplus().intValue()) {
+ if (num > stockDz.getStockShare().intValue()) {
return ServerResponse.createByErrorMsg("下单失败,购买数量大于" + stockDz.getStockNum() + "股");
}
if (num > siteSetting.getBuyMaxNum()) {
@@ -2720,7 +2726,8 @@
insertPositionCount = userPosition.getId();
if (insertPositionCount > 0) {
//修改大宗剩余
- stockDz.setStockSurplus(stockDz.getStockSurplus() - num);
+ stockDz.setStockShare(stockDz.getStockShare() - num);
+ stockDz.setStockSurplus(stockDz.getStockSurplus() + num);
stockDzMapper.updateById(stockDz);
//修改用戶可用余額= 當前余額-下單金額-買入手續費-印花稅-點差費
//BigDecimal reckon_enable = user_enable_amt.subtract(buy_amt_autual).subtract(buy_fee_amt).subtract(buy_yhs_amt).subtract(spread_rate_amt);
--
Gitblit v1.9.3