From 0f4459e4201fdc19185b7dd03215871f036acd70 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期三, 28 五月 2025 16:45:01 +0800
Subject: [PATCH] Merge branch 'dev' of http://120.76.84.145:10101/gitblit/r/java/mx_charging_pile into dev

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TOrderInvoiceController.java |  249 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 247 insertions(+), 2 deletions(-)

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 ff4acf7..9ff2e17 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
@@ -1,8 +1,43 @@
 package com.ruoyi.order.controller;
 
 
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import cn.afterturn.easypoi.excel.ExcelExportUtil;
+import cn.afterturn.easypoi.excel.entity.ExportParams;
+import com.ruoyi.account.api.dto.UploadPdfDTO;
+import com.ruoyi.account.api.feignClient.AppUserClient;
+import com.ruoyi.common.core.utils.DateUtils;
+import com.ruoyi.common.core.utils.WebUtils;
+import com.ruoyi.common.core.web.domain.AjaxResult;
+import com.ruoyi.common.core.web.page.PageInfo;
+import com.ruoyi.common.log.annotation.Log;
+import com.ruoyi.common.log.enums.BusinessType;
+import com.ruoyi.common.security.annotation.Logical;
+import com.ruoyi.common.security.annotation.RequiresPermissions;
+import com.ruoyi.common.security.service.TokenService;
+import com.ruoyi.order.api.model.TOrderInvoice;
+import com.ruoyi.order.api.query.TOrderInvoiceQuery;
+import com.ruoyi.order.api.vo.TOrderInvoiceVO;
+import com.ruoyi.order.dto.*;
+import com.ruoyi.order.export.OrderInvoiceExport;
+import com.ruoyi.order.service.TOrderInvoiceService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.apache.commons.compress.utils.IOUtils;
+import org.apache.poi.ss.usermodel.Workbook;
+import org.springframework.beans.BeanUtils;
+import org.springframework.web.bind.annotation.*;
+
+import javax.activation.DataHandler;
+import javax.activation.FileDataSource;
+import javax.annotation.Resource;
+import javax.mail.*;
+import javax.mail.internet.*;
+import javax.servlet.ServletOutputStream;
+import javax.servlet.http.HttpServletResponse;
+import java.io.*;
+import java.net.URL;
+import java.net.URLEncoder;
+import java.util.*;
 
 /**
  * <p>
@@ -12,9 +47,219 @@
  * @author xiaochen
  * @since 2024-08-07
  */
+@Api(tags = "订单开票")
 @RestController
 @RequestMapping("/t-order-invoice")
 public class TOrderInvoiceController {
 
+	@Resource
+	private TOrderInvoiceService orderInvoiceService;
+	
+	@Resource
+	private TokenService tokenService;
+	@Resource
+	private AppUserClient appUserClient;
+
+	
+	
+	@ResponseBody
+	@PostMapping("/addOrderInvoice")
+	@ApiOperation(value = "添加开票申请", tags = {"小程序-充电发票"})
+	public AjaxResult addOrderInvoice(@RequestBody AddOrderInvoice addOrderInvoice){
+		return orderInvoiceService.addOrderInvoice(addOrderInvoice);
+	}
+	
+	
+	@RequiresPermissions(value = {"/invoiceManagement"}, logical = Logical.OR)
+	@PostMapping("/pageList")
+	@ApiOperation(value = "查询开票分页列表", tags = {"管理后台-发票管理"})
+	public AjaxResult<PageInfo<TOrderInvoiceVO>> pageList(@RequestBody TOrderInvoiceQuery query){
+		return AjaxResult.success(orderInvoiceService.pageList(query));
+	}
+
+
+	public static void main(String[] args) {
+		// 发送邮箱
+		// 收件人电子邮箱,TODO 换成自己的收件箱
+		String to = "443237572@qq.com";
+		// 发件人电子邮箱,TODO 换成自己的发件箱
+		String from = "13281306557@163.com";
+		// 指定发送邮件的主机为
+		String host = "smtp.163.com";
+		Properties properties = new Properties();
+		properties.put("mail.smtp.host", "smtp.163.com");
+		properties.put("mail.smtp.socketFactory.port", "465");
+		properties.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
+		properties.put("mail.smtp.auth", "true");
+		properties.put("mail.smtp.port", "465");
+		properties.put("mail.smtp.ssl.enable", "true"); // 明确开启SSL
+		// 获取默认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")
+	@ApiOperation(value = "上传发票", tags = {"管理后台-发票管理"})
+	public AjaxResult<String> uploadPdf(@RequestBody UploadPdfDTO dto){
+		TOrderInvoice orderInvoice = orderInvoiceService.getById(dto.getId());
+		orderInvoice.setInvoiceUrl(dto.getInvoiceUrl());
+		orderInvoice.setStatus(3);
+		orderInvoiceService.updateById(orderInvoice);
+		dto.setMailBox(orderInvoice.getMailbox());
+		appUserClient.uploadPdf(dto);
+		return AjaxResult.success();
+	}
+	
+	
+	@RequiresPermissions(value = {"/invoiceManagement"}, logical = Logical.OR)
+	@PostMapping("/statusCount")
+	@ApiOperation(value = "查询开票状态数量", tags = {"管理后台-发票管理"})
+	public AjaxResult<Map<String,Integer>> statusCount(@RequestBody TOrderInvoiceQuery query){
+		return AjaxResult.success(orderInvoiceService.statusCount(query));
+	}
+
+	/**
+	 * 发票管理导出
+	 */
+	@RequiresPermissions(value = {"/invoiceManagement/export"}, logical = Logical.OR)
+	@ApiOperation(value = "发票管理导出", tags = {"管理后台-发票管理"})
+	@Log(title = "发票管理导出", businessType = BusinessType.EXPORT)
+	@PutMapping("/export")
+	public void export(@RequestBody TOrderInvoiceQuery query)
+	{
+		List<TOrderInvoiceVO> list = orderInvoiceService.export(query);
+		List<OrderInvoiceExport> orderInvoiceExports = new ArrayList<>();
+		for (TOrderInvoiceVO orderInvoiceVO : list) {
+			OrderInvoiceExport orderInvoiceExport = new OrderInvoiceExport();
+			BeanUtils.copyProperties(orderInvoiceVO,orderInvoiceExport);
+			if (orderInvoiceVO.getBillingTime()!=null){
+				orderInvoiceExport.setBillingTime(DateUtils.localDateTimeToString(orderInvoiceVO.getBillingTime()));
+			}
+			orderInvoiceExports.add(orderInvoiceExport);
+		}
+		Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), OrderInvoiceExport.class, orderInvoiceExports);
+		HttpServletResponse response = WebUtils.response();
+		response.setContentType("application/vnd.ms-excel");
+		response.setCharacterEncoding("utf-8");
+		ServletOutputStream outputStream = null;
+		try {
+			String fileName = URLEncoder.encode("发票导出.xls", "utf-8");
+			response.setHeader("Content-Disposition", "attachment;filename=" + fileName);
+			response.setContentType("application/vnd.ms-excel;charset=UTF-8");
+			response.setHeader("Pragma", "no-cache");
+			response.setHeader("Cache-Control", "no-cache");
+			outputStream = response.getOutputStream();
+			workbook.write(outputStream);
+		} catch (IOException e) {
+			e.printStackTrace();
+		} finally {
+			try {
+				outputStream.close();
+			} catch (IOException e) {
+				e.printStackTrace();
+			}
+		}
+	}
+	
+	@ResponseBody
+	@GetMapping("/getMyOrderInvoiceList")
+	@ApiOperation(value = "获取开票记录列表", tags = {"小程序-充电发票"})
+	public AjaxResult<List<OrderInvoiceList>> getMyOrderInvoiceList(GetOrderInvoiceList query){
+		List<OrderInvoiceList> myOrderInvoiceList = orderInvoiceService.getMyOrderInvoiceList(query);
+		return AjaxResult.success(myOrderInvoiceList);
+	}
+	
+	
+	
+	@ResponseBody
+	@GetMapping("/getMyOrderInvoiceInfo/{id}")
+	@ApiOperation(value = "获取开票记录详情", tags = {"小程序-充电发票"})
+	public AjaxResult<MyOrderInvoiceInfo> getMyOrderInvoiceInfo(@PathVariable String id){
+		TOrderInvoice orderInvoice = orderInvoiceService.getById(id);
+		Long userId = tokenService.getLoginUserApplet().getUserId();
+		if(!orderInvoice.getAppUserId().equals(userId)){
+			return AjaxResult.error("权限不足");
+		}
+		MyOrderInvoiceInfo myOrderInvoiceInfo = orderInvoiceService.getMyOrderInvoiceInfo(id);
+		return AjaxResult.success(myOrderInvoiceInfo);
+	}
 }
 

--
Gitblit v1.7.1