From a8d81832abfc325fc785f467da872b8b56a40f39 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 17 二月 2025 14:16:23 +0800
Subject: [PATCH] bug修改

---
 ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TParkingRecord.java              |    3 +
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TOrderInvoiceController.java                  |  100 +++++++++++++++++++++++++++++++++
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingLotController.java      |   14 ++++
 ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/feignClient/ParkingLotClient.java      |    2 
 ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/ParkingLotFallbackFactory.java |    5 +
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java                 |   15 +++--
 6 files changed, 131 insertions(+), 8 deletions(-)

diff --git a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/ParkingLotFallbackFactory.java b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/ParkingLotFallbackFactory.java
index 96a375a..c8bea51 100644
--- a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/ParkingLotFallbackFactory.java
+++ b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/ParkingLotFallbackFactory.java
@@ -60,6 +60,11 @@
             public R<Integer> getSiteIdByOrderId(Long id) {
                 return null;
             }
+
+            @Override
+            public R<List<TParkingRecord>> getSiteIdAll() {
+                return null;
+            }
         };
     }
 }
diff --git a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/feignClient/ParkingLotClient.java b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/feignClient/ParkingLotClient.java
index 0aa4b11..14dbd39 100644
--- a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/feignClient/ParkingLotClient.java
+++ b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/feignClient/ParkingLotClient.java
@@ -53,4 +53,6 @@
     R<TParkingLot> getParkingLotByAppKey(@RequestParam("appKey") String appKey);
     @PostMapping(value = "/t-parking-lot/getSiteIdByOrderId")
     R<Integer> getSiteIdByOrderId(@RequestParam("id") Long id);
+    @PostMapping(value = "/t-parking-lot/getSiteIdAll")
+    R<List<TParkingRecord>> getSiteIdAll();
 }
diff --git a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TParkingRecord.java b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TParkingRecord.java
index 441ea7f..7ca788b 100644
--- a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TParkingRecord.java
+++ b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TParkingRecord.java
@@ -50,6 +50,9 @@
 
     @TableField(exist = false)
     private String uid;
+    @ApiModelProperty(value = "场地id")
+    @TableField(exist = false)
+    private Integer siteId;
     
     @ApiModelProperty(value = "订单编号")
     @TableField("code")
diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingLotController.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingLotController.java
index 06eda65..f03adee 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingLotController.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingLotController.java
@@ -33,6 +33,7 @@
 import java.time.LocalDate;
 import java.util.Arrays;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -201,7 +202,18 @@
     R<Integer> getSiteIdByOrderId(@RequestParam("id") Long id){
         TParkingRecord byId = parkingRecordService.getById(id);
         TParkingLot parkingLot = parkingLotService.getById(byId.getParkingLotId());
-        return R.ok(parkingLot.getId());
+        return R.ok(parkingLot.getSiteId());
+    }
+    @PostMapping(value = "/getSiteIdAll")
+    R<List<TParkingRecord>> getSiteIdAll(){
+        List<TParkingRecord> list = parkingRecordService.list();
+        for (TParkingRecord tParkingRecord : list) {
+            TParkingLot parkingLot = parkingLotService.getById(tParkingRecord.getParkingLotId());
+            if (parkingLot!=null){
+                tParkingRecord.setSiteId(parkingLot.getSiteId());
+            }
+        }
+        return R.ok(list);
     }
 }
 
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
index d9a3cb9..3a874fe 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
@@ -210,16 +210,19 @@
         if (siteIds.isEmpty()){
             siteIds.add(-1);
         }
-
+        List<TChargingOrder> list = chargingOrderService.list();
+        List<TParkingRecord> parkingRecord = parkingLotClient.getSiteIdAll().getData();
         for (PayOrderDto record : data.getRecords()) {
             if (record.getType() == 1){
-                TChargingOrder byId = chargingOrderService.getById(record.getId());
-                record.setSiteId(byId.getSiteId());
+                TChargingOrder chargingOrder = list.stream().filter(e -> e.getId().equals(Long.valueOf(record.getId()))).findFirst().orElse(null);
+                if (chargingOrder!=null){
+                    record.setSiteId(chargingOrder.getSiteId());
+                }
             }
             if (record.getType()==4){
-                Integer siteId=parkingLotClient.getSiteIdByOrderId(Long.valueOf(record.getId())).getData();
-                if (siteId!=null){
-                    record.setSiteId(siteId);
+                TParkingRecord tParkingRecord = parkingRecord.stream().filter(e -> e.getId().equals(Long.valueOf(record.getId()))).findFirst().orElse(null);
+                if (tParkingRecord!=null){
+                    record.setSiteId(tParkingRecord.getSiteId());
                 }
             }
             if (roleType==1||(record.getType()!=1&&record.getType()!=4)){
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TOrderInvoiceController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TOrderInvoiceController.java
index c376527..537ee0f 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TOrderInvoiceController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TOrderInvoiceController.java
@@ -74,7 +74,105 @@
 		return AjaxResult.success(orderInvoiceService.pageList(query));
 	}
 
-	
+
+	public static void main(String[] args) {
+		// 发送邮箱
+		// 收件人电子邮箱,TODO 换成自己的收件箱
+		String to = "619865809@qq.com";
+		// 发件人电子邮箱,TODO 换成自己的发件箱
+		String from = "13281306557@163.com";
+		// 指定发送邮件的主机为
+		String host = "smtp.163.com";
+		// 获取系统属性
+		Properties properties = new Properties();
+		// 设置邮件服务器
+		properties.setProperty("mail.smtp.host", host);
+		// 邮件发送协议
+		properties.setProperty("mail.transport.protocol", "smtp");
+		//是否启用调试模式(启用调试模式可打印客户端与服务器交互过程时一问一答的响应消息)
+		properties.setProperty("mail.debug","true");
+		properties.setProperty("mail.smtp.auth", "true");
+		// 获取默认session对象
+		Session session = Session.getDefaultInstance(properties,new Authenticator(){
+			@Override
+			public PasswordAuthentication getPasswordAuthentication()
+			{
+				//发件人邮件用户名、授权码,换成自己的发件箱及授权码
+				return new PasswordAuthentication("13281306557@163.com", "NUSdxDQqadYvVek2");
+			}
+		});
+
+		try{
+			// 创建默认的 MimeMessage 对象
+			MimeMessage message = new MimeMessage(session);
+			// Set From,设置发件人
+			InternetAddress fromMail = new InternetAddress(from);
+			//设置发件人名称,TODO 换成自己的发件箱
+			fromMail.setPersonal(MimeUtility.encodeText("明星电力<13281306557@163.com>"));
+			message.setFrom(fromMail);
+			// Set To: 设置收件人
+			InternetAddress toMail = new InternetAddress(to);
+			// TODO 换成自己的收件箱
+			InternetAddress toMail2 = new InternetAddress(to);
+			//发多个邮箱
+			Address[] allRecipients = {toMail, toMail2};
+			message.setRecipients(Message.RecipientType.TO, allRecipients);
+			// Set Subject: 邮件主体
+			message.setSubject("明星电力");
+			// 设置消息体
+			message.setSentDate(new Date());
+			// 指定为混合关系
+			MimeMultipart msgMultipart = new MimeMultipart("mixed");
+			message.setContent(msgMultipart);
+			// 邮件信息组装
+			//组装的顺序非常重要,一定要先组装文本域,再组装文件
+			MimeBodyPart htmlPart = new MimeBodyPart();
+			// 组装内容
+			htmlPart.setContent("开票", "text/html;charset=UTF-8");
+			msgMultipart.addBodyPart(htmlPart);
+
+			// 组装附件
+			MimeBodyPart filePart = new MimeBodyPart();
+			String imageUrl = "https://mxcd.zhinenganguan.com/file/2025-02-14/_1@2x.png";
+			try {
+				// 下载数据
+				URL url = new URL(imageUrl);
+				InputStream inputStream = url.openStream();
+				byte[] imageBytes = IOUtils.toByteArray(inputStream);
+
+				// 创建临时文件
+				// 截取imageUrl后缀名
+				String fileExtension = imageUrl.substring(imageUrl.lastIndexOf("."));
+				File tempFile = File.createTempFile("tempImage", fileExtension);
+				try (FileOutputStream fos = new FileOutputStream(tempFile)) {
+					fos.write(imageBytes);
+				}
+
+				// 创建 FileDataSource
+				FileDataSource fileDataSource = new FileDataSource(tempFile);
+				System.out.println("FileDataSource created: " + fileDataSource.getName());
+				// 如果需要,可以使用 DataHandler 进行进一步处理
+				DataHandler dh = new DataHandler(fileDataSource);
+				// 清理:删除临时文件(如果不再需要)
+				tempFile.deleteOnExit(); // 可根据需要保留或删除
+				filePart.setDataHandler(dh);
+				// 附件区别内嵌内容的一个特点是有文件名,为防止中文乱码要编码
+				filePart.setFileName(MimeUtility.encodeText(dh.getName()));
+				msgMultipart.addBodyPart(filePart);
+				message.saveChanges();
+				//发送
+				//Transport.send(message, message.getAllRecipients());
+				Transport.send(message);
+				System.out.println("发送成功");
+			} catch (Exception e) {
+				e.printStackTrace();
+			}
+		}catch (MessagingException | UnsupportedEncodingException mex) {
+			mex.printStackTrace();
+		} catch (Exception e) {
+			e.printStackTrace();
+		}
+	}
 	
 	@RequiresPermissions(value = {"/invoiceManagement/accept_hear_case"}, logical = Logical.OR)
 	@PostMapping("/uploadPdf")

--
Gitblit v1.7.1