Compare commits

...

5 Commits

Author SHA1 Message Date
WL beba4dae71 更新最新代码 2025-03-18 20:08:32 +08:00
WL 803594ec1b 更新最新代码 2025-03-18 14:23:46 +08:00
wanglei 904afb2f29 更新最新代码 2025-03-17 22:48:10 +08:00
WL dd71b05dbb 更新最新代码 2025-03-17 17:41:00 +08:00
liyongxiang 60c33535e8 新增测试接口 2025-03-14 14:15:00 +08:00
14 changed files with 369 additions and 9 deletions

12
demo/.idea/misc.xml Normal file
View File

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="MavenProjectsManager">
<option name="originalFiles">
<list>
<option value="$PROJECT_DIR$/pom.xml" />
</list>
</option>
</component>
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="true" project-jdk-name="1.8" project-jdk-type="JavaSDK" />
</project>

124
demo/.idea/uiDesigner.xml Normal file
View File

@ -0,0 +1,124 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="Palette2">
<group name="Swing">
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
</item>
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
</item>
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
</item>
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.svg" removable="false" auto-create-binding="false" can-attach-label="true">
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
</item>
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
<initial-values>
<property name="text" value="Button" />
</initial-values>
</item>
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
<initial-values>
<property name="text" value="RadioButton" />
</initial-values>
</item>
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
<initial-values>
<property name="text" value="CheckBox" />
</initial-values>
</item>
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
<initial-values>
<property name="text" value="Label" />
</initial-values>
</item>
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
<preferred-size width="150" height="-1" />
</default-constraints>
</item>
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
<preferred-size width="150" height="-1" />
</default-constraints>
</item>
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
<preferred-size width="150" height="-1" />
</default-constraints>
</item>
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
</item>
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
<preferred-size width="200" height="200" />
</default-constraints>
</item>
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
<preferred-size width="200" height="200" />
</default-constraints>
</item>
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
</item>
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
</item>
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
</item>
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
</item>
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
<preferred-size width="-1" height="20" />
</default-constraints>
</item>
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
</item>
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
</item>
</group>
</component>
</project>

View File

@ -17,14 +17,20 @@
package com.example.demo.demos.web.controller;
import com.alibaba.fastjson.JSON;
import com.example.demo.model.ElePriceInfoModel;
import com.example.demo.model.ElecBindInfoModel;
import com.example.demo.model.Response;
import com.example.demo.model.User;
import com.example.demo.service.BasicService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import java.util.Enumeration;
import java.util.Map;
/**
@ -45,6 +51,40 @@ public class BasicController {
log.info("获取电费相关信息响应:{}", JSON.toJSONString(response));
return response;
}
@PostMapping("/getElectricityInfo1")
@ResponseBody
public Object getElectricityInfo1(@RequestBody Map<String,Object> param) {
log.info("获取电费相关1信息入参{}", JSON.toJSONString(param));
Object response = basicService.getElectricityInfo1(param);
log.info("获取电费相关1信息入参{}", JSON.toJSONString(response));
return response;
}
@PostMapping("/getBindingInfo")
@ResponseBody
public Object getBindingInfo(HttpServletRequest request, @RequestBody ElecBindInfoModel model) {
Object response = new Object();
log.info("获取绑定信息入参token={}model{}", request.getHeader("x_auth_token"),JSON.toJSONString(model));
if (null ==model || !(StringUtils.hasText(model.getPhone()) || StringUtils.hasText(model.getElecNumber())|| StringUtils.hasText(model.getUserNumber())||
StringUtils.hasText(model.getProvince()) || StringUtils.hasText(model.getCity())|| StringUtils.hasText(model.getCityCode()))){
String token = request.getHeader("x_auth_token");
response = basicService.getBindingInfo(model);
}
response = basicService.getBindingInfo(model);
log.info("获取绑定信息返回:{}", JSON.toJSONString(response));
return response;
}
@PostMapping("/getElePriceInfo")
@ResponseBody
public Object getElePriceInfo(@RequestBody ElePriceInfoModel model) {
Object response = new Object();
log.info("获取历史电价信息入参model{}", JSON.toJSONString(model));
response = basicService.getElePriceInfo(model);
log.info("获取绑定信息返回:{}", JSON.toJSONString(response));
return response;
}
// http://127.0.0.1:8080/user
@RequestMapping("/user")

View File

@ -0,0 +1,13 @@
package com.example.demo.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.demo.model.ElecBindInfo;
import com.example.demo.model.ElectricityBill;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
@Mapper
public interface ElecBillInfoMapper extends BaseMapper<ElecBindInfo> {
}

View File

@ -0,0 +1,10 @@
package com.example.demo.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.demo.model.ElecPriceHistory;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface ElecPrivceHistoryMapper extends BaseMapper<ElecPriceHistory> {
}

View File

@ -0,0 +1,18 @@
package com.example.demo.model;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;
import org.springframework.stereotype.Component;
@Data
@Component
public class ElePriceInfoModel {
private String province;
private String city;
private String isSummer;
private String elecGradient;
private String elecType;
private String startTime;
private String endTime;
}

View File

@ -0,0 +1,23 @@
package com.example.demo.model;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;
import org.springframework.stereotype.Component;
@Data
@Component
public class ElecBindInfo {
@TableId
private String id;
private String province;
private String city;
private String bindType;
private String elecNumber;
private String phone;
private String electricityAddress;
private String userNumber;
private String cityCode;
private String elecType;
private String userName;
}

View File

@ -0,0 +1,18 @@
package com.example.demo.model;
import lombok.Data;
import org.springframework.stereotype.Component;
@Data
@Component
public class ElecBindInfoModel {
private String province;
private String city;
private String bindType;
private String elecNumber;
private String phone;
private String electricityAddress;
private String userNumber;
private String cityCode;
}

View File

@ -0,0 +1,20 @@
package com.example.demo.model;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;
import org.springframework.stereotype.Component;
@Data
@Component
public class ElecPriceHistory {
@TableId
private String id;
private String province;
private String city;
private String isSummer;
private String elecGradient;
private String elecType;
private String effectiveTime;
private String elecPrice;
}

View File

@ -1,5 +1,7 @@
package com.example.demo.service;
import com.example.demo.model.ElePriceInfoModel;
import com.example.demo.model.ElecBindInfoModel;
import com.example.demo.model.Response;
import org.springframework.stereotype.Service;
import org.springframework.web.bind.annotation.RequestBody;
@ -10,4 +12,10 @@ import java.util.Map;
public interface BasicService {
Response getElectricityInfo(Map<String,Object> param);
Object getElectricityInfo1(Map<String,Object> param);
Object getBindingInfo(ElecBindInfoModel model);
Object getElePriceInfo(ElePriceInfoModel model);
}

View File

@ -1,20 +1,19 @@
package com.example.demo.service.impl;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.example.demo.constant.EleConstant;
import com.example.demo.constant.StaConstant;
import com.example.demo.mapper.ElecBillInfoMapper;
import com.example.demo.mapper.ElecPrivceHistoryMapper;
import com.example.demo.mapper.ElectricityBillMapper;
import com.example.demo.model.DataAndView;
import com.example.demo.model.ElectricityBill;
import com.example.demo.model.Response;
import com.example.demo.model.TypeAndQuery;
import com.example.demo.model.*;
import com.example.demo.service.BasicService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@ -25,6 +24,12 @@ public class BasicServiceImpl implements BasicService {
@Autowired
ElectricityBillMapper electricityBillMapper;
@Autowired
ElecBillInfoMapper elecBillInfoMapper;
@Autowired
ElecPrivceHistoryMapper elecPrivceHistoryMapper;
@Override
public Response getElectricityInfo(Map<String, Object> param) {
String keyWord = (String) param.get("kw");
@ -64,6 +69,64 @@ public class BasicServiceImpl implements BasicService {
return response;
}
@Override
public Object getElectricityInfo1(Map<String, Object> param) {
String keyWord = (String) param.get("kw");
DataAndView dataAndView =new DataAndView();
List<ElectricityBill> bills = new ArrayList<>();
TypeAndQuery typeAndQuery = new TypeAndQuery();
analysisKeyWord(keyWord,typeAndQuery);
dataAndView.setType(typeAndQuery.getType());
log.info("数据库查询电费!");
bills = electricityBillMapper.queryElectricityByDate();
StringBuilder electricityBill =new StringBuilder();
StringBuilder statementDate =new StringBuilder();
bills.stream().forEach(bill ->{
electricityBill.append(bill.getElectricityBill()).append(";");
statementDate.append(bill.getStatementDate()).append(";");
});
Map<String,String> result = new HashMap<>();
result.put("electricityBill",electricityBill.deleteCharAt(electricityBill.length()-1).toString());
result.put("statementDate",statementDate.deleteCharAt(electricityBill.length()-1).toString());
dataAndView.setData(result);
return dataAndView;
}
@Override
public Object getBindingInfo(ElecBindInfoModel model) {
QueryWrapper<ElecBindInfo> queryWrapper =new QueryWrapper<>();
Map<String,Object> map = new HashMap<>();
map.put("phone",model.getPhone());
map.put("province",model.getProvince());
map.put("city",model.getCity());
map.put("elec_number",model.getElecNumber());
map.put("city_code",model.getCityCode());
map.put("user_number",model.getUserNumber());
queryWrapper.allEq(map,false);
return elecBillInfoMapper.selectList(queryWrapper);
}
@Override
public Object getElePriceInfo(ElePriceInfoModel model) {
QueryWrapper<ElecPriceHistory> queryWrapper =new QueryWrapper<>();
Map<String,Object> map = new HashMap<>();
List<Map<String,String>> result = new ArrayList<>();
map.put("is_summer",model.getIsSummer());
map.put("elec_gradient",model.getElecGradient());
map.put("elec_type",model.getElecType());
queryWrapper.allEq(map,false)
.between("effective_time",model.getStartTime(),model.getEndTime())
.like("province",model.getProvince())
.like("city",model.getCity());
List<ElecPriceHistory> elecPriceHistories = elecPrivceHistoryMapper.selectList(queryWrapper);
elecPriceHistories.stream().forEach(e ->{
Map<String,String> priceMap = new HashMap<>();
priceMap.put("price",e.getElecPrice());
priceMap.put("date",e.getEffectiveTime());
result.add(priceMap);
});
return result;
}
private void analysisKeyWord(String keyWord,TypeAndQuery typeAndQuery){
int querySymbol = 0;

View File

@ -2,9 +2,9 @@
server.port=9090
# DataSource configuration using HikariCP (default connection pool in Spring Boot)
spring.datasource.url=jdbc:mysql://120.78.126.4:5455/rag_flow?useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true
spring.datasource.url=jdbc:mysql://120.78.126.4:9200/elec?useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=infini_rag_flow
spring.datasource.password=AL@2025
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
# HikariCP specific properties (optional)
spring.datasource.hikari.maximum-pool-size=10
@ -20,5 +20,5 @@ type-aliases-package: com.example.demo.model #需要配置成你当前包下的
configuration:
#开启驼峰命名
map-underscore-to-camel-case: true
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.ElecBillInfoMapper">
</mapper>

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.ElecPrivceHistoryMapper">
</mapper>