From dd663d0ac783755d889e270eee57ee58630c88c8 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 28 二月 2025 17:46:52 +0800
Subject: [PATCH] 冥想2.0新增代码

---
 xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserBankController.java |  209 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 209 insertions(+), 0 deletions(-)

diff --git a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserBankController.java b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserBankController.java
index 0891805..5cacfc1 100644
--- a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserBankController.java
+++ b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserBankController.java
@@ -1,8 +1,25 @@
 package com.xinquan.user.controller.client;
 
 
+import com.xinquan.common.core.domain.R;
+import com.xinquan.system.api.domain.AppUserBlack;
+import com.xinquan.system.api.model.LoginUser;
+import io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
+import io.swagger.annotations.ApiOperation;
+import org.apache.commons.compress.utils.IOUtils;
+import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
+
+import javax.activation.DataHandler;
+import javax.activation.FileDataSource;
+import javax.mail.*;
+import javax.mail.internet.*;
+import java.io.*;
+import java.net.URL;
+import java.util.Date;
+import java.util.Properties;
 
 /**
  * <p>
@@ -16,5 +33,197 @@
 @RequestMapping("/client/app-user-bank")
 public class ClientAppUserBankController {
 
+    @PostMapping("/blackUser")
+    @ApiOperation(value = "取消拉黑功能", tags = "IOS拉黑列表--用于上架")
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "被拉黑用户id", name = "appUserId", required = true, dataType = "Long"),
+    })
+    public R blackUser(Long appUserId) {
+        // 发送邮箱
+        // 收件人电子邮箱,TODO 换成自己的收件箱
+        String to = "443237572@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.smtp.port", "465"); // 使用SSL端口
+        // 邮件发送协议
+        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();
+        }
+        return R.ok();
+    }
+
+    public static void main(String[] args) throws MessagingException, IOException {
+        // 发送邮箱
+        // 收件人电子邮箱,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");
+            }
+        });
+            // 创建默认的 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";
+                // 下载数据
+                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("发送成功");
+    }
 }
 

--
Gitblit v1.7.1