From 43f6f6270ecd47542e6c64450d2e3d6b8526304e Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Fri, 12 Jul 2024 17:51:29 +0800
Subject: [PATCH] 1

---
 src/main/java/com/nq/service/impl/PriceServicesImpl.java |  130 +++++++++++++++++++++++--------------------
 1 files changed, 70 insertions(+), 60 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/PriceServicesImpl.java b/src/main/java/com/nq/service/impl/PriceServicesImpl.java
index 71345ac..5226333 100644
--- a/src/main/java/com/nq/service/impl/PriceServicesImpl.java
+++ b/src/main/java/com/nq/service/impl/PriceServicesImpl.java
@@ -11,6 +11,7 @@
 import com.nq.pojo.*;
 import com.nq.service.IPriceServices;
 import com.nq.service.IStockConfigServices;
+import com.nq.utils.PropertiesUtil;
 import com.nq.utils.http.HttpClientRequest;
 import com.nq.utils.redis.RedisKeyUtil;
 import com.nq.utils.timeutil.TimeUtil;
@@ -18,21 +19,20 @@
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
-import java.io.BufferedReader;
-import java.io.InputStreamReader;
+import java.io.*;
 import java.lang.reflect.Type;
 import java.math.BigDecimal;
-import  java.io.BufferedReader;
-import  java.io.InputStreamReader;
-import  java.net.HttpURLConnection;
-import  java.net.URL;
+import java.io.BufferedReader;
+import java.io.InputStreamReader;
+import java.net.HttpURLConnection;
+import java.net.URL;
 import java.util.HashMap;
 import java.util.Map;
+
 import com.fasterxml.jackson.databind.ObjectMapper;
 
 @Service
-public class PriceServicesImpl  implements IPriceServices {
-
+public class PriceServicesImpl implements IPriceServices {
 
 
     @Resource
@@ -50,41 +50,40 @@
 
     @Override
     public BigDecimal getNowPrice(String stockCode) {
-        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code",stockCode));
-        StockSetting stockSetting = stockSettingMapper.selectOne(new QueryWrapper<StockSetting>().eq("stock_code",stockCode));
-        if(stockSetting != null){
-            if(TimeUtil.isTradingHour(stockSetting.getStartTime(),stockSetting.getEndTime())){
-                if(stockSetting.getType().equals("0")){
-                    return  new BigDecimal(stockSetting.getPrice());
-                }else{
-                    String s = doGet(stock.getStockCode());
-                    if(null != s){
+        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", stockCode));
+        StockSetting stockSetting = stockSettingMapper.selectOne(new QueryWrapper<StockSetting>().eq("stock_code", stockCode));
+        if (stockSetting != null) {
+            if (TimeUtil.isTradingHour(stockSetting.getStartTime(), stockSetting.getEndTime())) {
+                if (stockSetting.getType().equals("0")) {
+                    return new BigDecimal(stockSetting.getPrice());
+                } else {
+                    String s = doPost(stock.getStockCode());
+                    if (null != s) {
                         Map<String, Object> stringObjectMap = jsonToMap(s);
-                        return   new BigDecimal(stringObjectMap.get("last").toString()).multiply(new BigDecimal(stockSetting.getPrice()));
+                        return new BigDecimal(stringObjectMap.get("last").toString()).multiply(new BigDecimal(stockSetting.getPrice()));
                     }
                 }
             }
         }
 
-        String s = doGet(stock.getStockCode());
-        if(null != s) {
+        String s = doPost(stock.getStockCode());
+        if (null != s) {
             Map<String, Object> stringObjectMap = jsonToMap(s);
-            return  new BigDecimal(stringObjectMap.get("last").toString());
+            return new BigDecimal(stringObjectMap.get("last").toString());
         }
         return BigDecimal.ZERO;
     }
 
     @Override
     public Map<String, Object> getNewStock(String stockCode) {
-        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code",stockCode));
-        String s = doGet(stock.getStockCode());
-        if(null != s){
+        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", stockCode));
+        String s = doPost(stock.getStockCode());
+        if (null != s) {
             Map<String, Object> stringObjectMap = jsonToMap(s);
-            return   stringObjectMap;
+            return stringObjectMap;
         }
         return null;
     }
-
 
 
     public static Map<String, Object> jsonToMap(String json) {
@@ -100,23 +99,33 @@
         }
     }
 
-    public String doGet(String pid){
-        String  apiUrl  =  "http://api-in-2.js-stock.top/stock?pid="+pid+"&key=eVKtHt7aG4m6ozwWL9qG";
-        try  {
-            URL  url  =  new  URL(apiUrl);
-            HttpURLConnection  connection  =  (HttpURLConnection)  url.openConnection();
-            connection.setRequestMethod("GET");
+    public String doPost(String pid) {
 
-            BufferedReader in  =  new  BufferedReader(new InputStreamReader(connection.getInputStream()));
-            String  inputLine;
-            StringBuffer  response  =  new  StringBuffer();
+        try {
+            String url = PropertiesUtil.getProperty("JP_HTTP_API") + "stock?version=v1&key=" + PropertiesUtil.getProperty("JP_KEY");
+            URL obj = new URL(url);
+            HttpURLConnection con = (HttpURLConnection) obj.openConnection();
 
-            while  ((inputLine  =  in.readLine())  !=  null)  {
+            con.setRequestMethod("POST");
+            con.setDoOutput(true);
+
+            String body = "pid=" + pid;
+            OutputStream os = con.getOutputStream();
+            BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(os, "UTF-8"));
+            writer.write(body);
+            writer.flush();
+            writer.close();
+            os.close();
+            BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream()));
+            String inputLine;
+            StringBuffer response = new StringBuffer();
+
+            while ((inputLine = in.readLine()) != null) {
                 response.append(inputLine);
             }
             in.close();
             return response.toString();
-        }  catch  (Exception  e)  {
+        } catch (Exception e) {
             e.printStackTrace();
         }
         return null;
@@ -124,37 +133,38 @@
 
     @Override
     public BigDecimal getNowPrice(String stockCode, String stockType) {
-      BigDecimal nowPrice =   getNowPrice(stockCode);
-      if (!stockType.equals("DZ")){
-          return  nowPrice;
-      }
-     QueryWrapper queryWrapper =    new QueryWrapper<>();
-        queryWrapper.eq("stock_code",stockCode);
-       StockDz stockDz =  stockDZMapper.selectOne(queryWrapper);
-       if(stockDz == null){
-           return  nowPrice;}
-       return  nowPrice.multiply(stockDz.getDiscount());
+        BigDecimal nowPrice = getNowPrice(stockCode);
+        if (!stockType.equals("DZ")) {
+            return nowPrice;
+        }
+        QueryWrapper queryWrapper = new QueryWrapper<>();
+        queryWrapper.eq("stock_code", stockCode);
+        StockDz stockDz = stockDZMapper.selectOne(queryWrapper);
+        if (stockDz == null) {
+            return nowPrice;
+        }
+        return nowPrice.multiply(stockDz.getDiscount());
     }
 
     @Override
     public boolean isLimitUpBuy(String stockCode) {
-        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code",stockCode));
-        StockRealTimeBean stockRealTimeBean =  RedisKeyUtil.getCacheRealTimeStock(stock);
+        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", stockCode));
+        StockRealTimeBean stockRealTimeBean = RedisKeyUtil.getCacheRealTimeStock(stock);
         BigDecimal pcp = new BigDecimal(stockRealTimeBean.getPcp());
         StockConfig stockConfig = iStockConfigServices.queryByKey(EConfigKey.LIMIT_UP_POINT.getCode());
-        if(stockConfig == null){
+        if (stockConfig == null) {
             return true;
         }
 
 
-        if(pcp.compareTo(new BigDecimal(0))<0){
-            return  true;
+        if (pcp.compareTo(new BigDecimal(0)) < 0) {
+            return true;
         }
 
-        if(new BigDecimal(stockConfig.getCValue()).compareTo(pcp)<=0){
+        if (new BigDecimal(stockConfig.getCValue()).compareTo(pcp) <= 0) {
             StockConfig limitConfig = iStockConfigServices.queryByKey(EConfigKey.LIMIT_UP_IS_BUY.getCode());
-            if(limitConfig.getCValue().equals("1")){
-                return  true;
+            if (limitConfig.getCValue().equals("1")) {
+                return true;
             }
             return false;
         }
@@ -163,16 +173,16 @@
 
     @Override
     public boolean isLimitDownSell(String stockCode) {
-        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code",stockCode));
-        StockRealTimeBean stockRealTimeBean =  RedisKeyUtil.getCacheRealTimeStock(stock);
+        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", stockCode));
+        StockRealTimeBean stockRealTimeBean = RedisKeyUtil.getCacheRealTimeStock(stock);
         BigDecimal pcp = new BigDecimal(stockRealTimeBean.getPcp());
         StockConfig stockConfig = iStockConfigServices.queryByKey(EConfigKey.LIMIT_DOWN_POINT.getCode());
-        if(stockConfig == null){
+        if (stockConfig == null) {
             return true;
         }
-        if(pcp.compareTo(new BigDecimal(stockConfig.getCValue()))<=0){
+        if (pcp.compareTo(new BigDecimal(stockConfig.getCValue())) <= 0) {
             StockConfig limitConfig = iStockConfigServices.queryByKey(EConfigKey.LIMIT_DOWN_IS_SELL.getCode());
-            if(!limitConfig.getCValue().equals("1")){
+            if (!limitConfig.getCValue().equals("1")) {
                 return false;
             }
         }

--
Gitblit v1.9.3