From 8853292babb2ad94de4a3207966f1e83b767cd2d Mon Sep 17 00:00:00 2001
From: zhongrj <646384940@qq.com>
Date: Sun, 17 Sep 2023 16:38:34 +0800
Subject: [PATCH] 新增流程节点进程查询接口

---
 src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java |  203 ++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 144 insertions(+), 59 deletions(-)

diff --git a/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java b/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java
index 888ecc4..04f9ff5 100644
--- a/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java
+++ b/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java
@@ -19,13 +19,14 @@
 import io.minio.*;
 import io.minio.errors.*;
 import io.swagger.annotations.Api;
-import javafx.scene.Parent;
 import lombok.AllArgsConstructor;
 import lombok.SneakyThrows;
+import org.apache.commons.lang3.StringUtils;
 import org.springblade.common.config.FileConfig;
-import org.springblade.common.constant.FtpConstant;
+import org.springblade.common.config.FtpConfig;
 import org.springblade.common.utils.FileUtil;
 import org.springblade.core.launch.constant.AppConstant;
+import org.springblade.core.log.exception.ServiceException;
 import org.springblade.core.oss.model.BladeFile;
 import org.springblade.core.oss.model.OssFile;
 import org.springblade.core.secure.annotation.PreAuth;
@@ -44,6 +45,7 @@
 import org.springblade.modules.resource.service.IAttachService;
 import org.springblade.modules.system.entity.User;
 import org.springblade.modules.system.service.IUserService;
+import org.springblade.modules.system.service.MyAsyncService;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
 import java.io.File;
@@ -54,9 +56,9 @@
 import java.security.NoSuchAlgorithmException;
 import java.text.SimpleDateFormat;
 import java.util.*;
+import java.util.concurrent.atomic.AtomicBoolean;
 import java.util.regex.Pattern;
-
-import static org.springblade.common.constant.FtpConstant.*;
+import static org.springblade.common.config.FtpConfig.*;
 
 /**
  * 对象存储端点
@@ -87,6 +89,7 @@
 	private final ExamPaperService examPaperService;
 
 	private final ExamPaymentService examPaymentService;
+	private final MyAsyncService myAsyncService;
 
 	/**
 	 * 创建存储桶
@@ -178,22 +181,24 @@
 	@PostMapping("/put-file")
 	public R<BladeFile> putFile(@RequestParam MultipartFile file) {
 		BladeFile bladeFile = ossBuilder.template().putFile(file.getOriginalFilename(), file.getInputStream());
+		bladeFile.setLink(bladeFile.getLink().replace("127.0.0.1","60.220.177.113"));
 		return R.data(bladeFile);
 	}
 
-
 	/**
-	 * app 文件上传
+	 * 上传文件
 	 *
-	 * @param file 图片对象
+	 * @param file 文件
+	 * @return ObjectStat
 	 */
-	@PostMapping("put-file-app")
-	public R putFileApp(@RequestParam MultipartFile file) throws IOException, ServerException, InsufficientDataException, InternalException, InvalidResponseException, InvalidKeyException, NoSuchAlgorithmException, XmlParserException, ErrorResponseException {
+	@SneakyThrows
+	@PostMapping("/put-file-user-avatar")
+	public R putFileUserAvatar(@RequestParam MultipartFile file) {
 		//填写你文件上传的地址以及相应信息
-		String url = "http://223.82.109.183:2081";
-		String access = "zhbaadmin";
-		String secret = "zhbapassword";
-		String bucket = "zhba";
+		String url = FileConfig.apiUrl;
+		String access = FileConfig.access;
+		String secret = FileConfig.secret;
+		String bucket = FileConfig.bucket;
 		MinioClient minioClient =
 			MinioClient.builder()
 				.endpoint(url)
@@ -221,10 +226,62 @@
 				in, in.available(), -1)
 				.headers(headers)
 				.build());
-		InputStream inputStream = file.getInputStream();
-		FtpUtil.uploadFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
+//		InputStream inputStream = file.getInputStream();
+//		FtpUtil.uploadFile(FtpConfig.ftpHost, ftpPort, FtpConfig.ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
 		in.close();
-		String urls = "http://223.82.109.183:2081/zhba/" + newName;
+		String urls = FileConfig.url + "/"+ FileConfig.bucket + "/" + newName;
+		//数据封装
+		Map<String, Object> map = new HashMap<>(2);
+		map.put("name", newName);
+		map.put("url", urls);
+		//返回
+		return R.data(map);
+	}
+
+
+	/**
+	 * app 文件上传
+	 *
+	 * @param file 图片对象
+	 */
+	@PostMapping("put-file-app")
+	public R putFileApp(@RequestParam MultipartFile file) throws IOException, ServerException, InsufficientDataException, InternalException, InvalidResponseException, InvalidKeyException, NoSuchAlgorithmException, XmlParserException, ErrorResponseException {
+		//填写你文件上传的地址以及相应信息
+		String url = FileConfig.apiUrl;
+		String access = FileConfig.access;
+		String secret = FileConfig.secret;
+		String bucket = FileConfig.bucket;
+		MinioClient minioClient =
+			MinioClient.builder()
+				.endpoint(url)
+				.credentials(access, secret)
+				.build();
+		// 检查存储桶是否已经存在
+		boolean isExist = minioClient.bucketExists(BucketExistsArgs.builder().bucket(bucket).build());
+		if (!isExist) {
+			// 创建一个名为zip的存储桶,用于zip文件。
+			minioClient.makeBucket(MakeBucketArgs.builder().bucket(bucket).build());
+			minioClient.setBucketPolicy(SetBucketPolicyArgs.builder().bucket(bucket).build());
+		}
+		String fileName = file.getOriginalFilename();
+		String newName = "upload/picture/" + UUID.randomUUID().toString().replaceAll("-", "")
+			+ fileName.substring(fileName.lastIndexOf("."));
+		InputStream in = file.getInputStream();
+		String[] split = newName.split("/");
+		//创建头部信息
+		Map<String, String> headers = new HashMap<>(1 << 2);
+		//添加自定义内容类型
+		headers.put("Content-Type", "application/octet-stream");
+		//上传
+		minioClient.putObject(
+			PutObjectArgs.builder().bucket(bucket).object(newName).stream(
+				in, in.available(), -1)
+				.headers(headers)
+				.build());
+//		InputStream inputStream = file.getInputStream();
+//		FtpUtil.uploadFile(ftpHost, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
+		in.close();
+		String urls = FileConfig.url + "/"+ FileConfig.bucket + "/" + newName;
 		return R.data(urls);
 	}
 
@@ -237,10 +294,10 @@
 	@PostMapping("put-files")
 	public R putFiles(@RequestParam MultipartFile file) throws IOException, ServerException, InsufficientDataException, InternalException, InvalidResponseException, InvalidKeyException, NoSuchAlgorithmException, XmlParserException, ErrorResponseException {
 		//填写你文件上传的地址以及相应信息
-		String url = "http://223.82.109.183:2081";
-		String access = "zhbaadmin";
-		String secret = "zhbapassword";
-		String bucket = "zhba";
+		String url = FileConfig.apiUrl;
+		String access = FileConfig.access;
+		String secret = FileConfig.secret;
+		String bucket = FileConfig.bucket;
 		MinioClient minioClient =
 			MinioClient.builder()
 				.endpoint(url)
@@ -268,10 +325,10 @@
 				in, in.available(), -1)
 				.headers(headers)
 				.build());
-		InputStream inputStream = file.getInputStream();
-		FtpUtil.uploadFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
+//		InputStream inputStream = file.getInputStream();
+//		FtpUtil.uploadFile(FtpConfig.ftpHost, ftpPort, FtpConfig.ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
 		in.close();
-		String urls = "http://223.82.109.183:2081/zhba/" + newName;
+		String urls = FileConfig.url + "/"+ FileConfig.bucket + "/" + newName;
 		//数据封装
 		Map<String, Object> map = new HashMap<>(2);
 		map.put("name", newName);
@@ -290,10 +347,10 @@
 	public R putFileZip(@RequestParam MultipartFile file) throws Exception {
 		Map<String, Object> map = new HashMap<>(1);
 		//填写你文件上传的地址以及相应信息
-		String url = "http://223.82.109.183:2081";
-		String access = "zhbaadmin";
-		String secret = "zhbapassword";
-		String bucket = "zhba";
+		String url = FileConfig.apiUrl;
+		String access = FileConfig.access;
+		String secret = FileConfig.secret;
+		String bucket = FileConfig.bucket;
 		MinioClient minioClient =
 			MinioClient.builder()
 				.endpoint(url)
@@ -311,8 +368,7 @@
 		String fileType = fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase(Locale.US);
 		//判断文件是不是zip类型
 		if(!fileType.equals("zip")){
-			map.put("data","上传文件类型不符!");
-			return R.data(map);
+			throw new ServiceException("上传文件类型不符!必须是 zip 压缩文件格式!");
 		}
 		//FileConfig.localtion是配置文件和config类生产的,测试demo可以直接把FileConfig.localtion替换成D:/test
 		String uuid = UUID.randomUUID().toString();
@@ -327,8 +383,25 @@
 
 		List<MultipartFile> fileList = new ArrayList<>();
 		//获取图片文件
-		fileList = fileUtil.getSubFiles(desPath+File.separator+namePath,fileList);
+//		fileList = fileUtil.getSubFiles(desPath+File.separator+namePath,fileList);
+		fileList = fileUtil.getSubFiles(desPath,fileList);
+		//将不能导入的保安员账号存起来
+		List<String> errorList = new ArrayList<>();
+		//导入状态,默认为true ,如果有一个出现问题则为 false
+		AtomicBoolean status = new AtomicBoolean(true);
+		//遍历
 		for (MultipartFile multipartFile : fileList){
+			long size = multipartFile.getSize();
+			if (size<30*1024 || size>500*1024){
+				status.set(false);
+				//取出身份证号,查询用户信息,更新用户信息
+				String pictrueName = multipartFile.getName().substring(0, multipartFile.getName().lastIndexOf("."));
+				String regex ="[\u4e00-\u9fa5]";
+				Pattern compile = Pattern.compile(regex);
+				String idCardNo = compile.matcher(pictrueName).replaceAll("");
+				//加入集合
+				errorList.add(idCardNo);
+			}
 			if(multipartFile.getName().toLowerCase().endsWith(".png") || multipartFile.getName().toLowerCase().endsWith(".jpg")) {
 				String newName = "upload/picture/" + UUID.randomUUID().toString().replaceAll("-", "") + multipartFile.getName().substring(multipartFile.getName().lastIndexOf("."));
 				InputStream in = multipartFile.getInputStream();
@@ -344,9 +417,9 @@
 						.headers(headers)
 						.build());
 
-				String urls = "http://223.82.109.183:2081/zhba/" + newName;
+				String urls = FileConfig.url + "/"+ FileConfig.bucket + "/" + newName;
 				//内网
-				String inUrl = ip + newName;
+				String inUrl = FtpConfig.ip + "/zhba/" + newName;
 				//取出身份证号,查询用户信息,更新用户信息
 				String pictrueName = multipartFile.getName().substring(0, multipartFile.getName().lastIndexOf("."));
 //				String regex ="([1-9]\\d{5}(18|19|20)\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3}[0-9Xx])|([1-9]\\d{5}\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3})";
@@ -362,12 +435,15 @@
 
 					//内网数据推送
 					//数据推送
-					String s = "update blade_user set avatar = " + "'" + inUrl + "'" + "where id = " + "'" + user.getId() + "'";
-					FtpUtil.sqlFileUpload(s);
+					String s = "update blade_user set avatar = " + "'" + inUrl +
+						",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()) + "'" +
+						"'" + "where id = " + "'" + user.getId() + "'";
+					//FtpUtil.sqlFileUpload(s);
+					myAsyncService.dataSync(s);
 
 					//文件推送
-					InputStream inputStream = multipartFile.getInputStream();
-					FtpUtil.uploadFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
+//					InputStream inputStream = multipartFile.getInputStream();
+//					FtpUtil.uploadFile(FtpConfig.ftpHost, ftpPort, FtpConfig.ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
 					in.close();
 				}
 			}
@@ -377,6 +453,10 @@
 		FileUtil.clearFiles(desPath);
 		//数据封装
 		map.put("data", "上传成功!");
+		if (!status.get()) {
+			String errorAccount = StringUtils.join(errorList, "\\\n");
+			throw new ServiceException("用户:[" + errorAccount + "]照片导入失败!照片不能小于30KB,且不能大于500KB!!");
+		}
 		//返回
 		return R.data(map);
 	}
@@ -391,10 +471,10 @@
 	public R putFileExamPaymentZip(@RequestParam MultipartFile file) throws Exception {
 		Map<String, Object> map = new HashMap<>(1);
 		//填写你文件上传的地址以及相应信息
-		String url = "http://223.82.109.183:2081";
-		String access = "zhbaadmin";
-		String secret = "zhbapassword";
-		String bucket = "zhba";
+		String url = FileConfig.apiUrl;
+		String access = FileConfig.access;
+		String secret = FileConfig.secret;
+		String bucket = FileConfig.bucket;
 		MinioClient minioClient =
 			MinioClient.builder()
 				.endpoint(url)
@@ -412,8 +492,9 @@
 		String fileType = fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase(Locale.US);
 		//判断文件是不是zip类型
 		if(!fileType.equals("zip")){
-			map.put("data","上传文件类型不符!");
-			return R.data(map);
+//			map.put("data","上传文件类型不符!");
+//			return R.data(map);
+			throw new ServiceException("上传文件类型不符!必须是 zip 压缩文件格式!");
 		}
 		//FileConfig.localtion是配置文件和config类生产的,测试demo可以直接把FileConfig.localtion替换成D:/test
 		String uuid = UUID.randomUUID().toString();
@@ -427,7 +508,7 @@
 
 		List<MultipartFile> fileList = new ArrayList<>();
 		//获取图片文件
-		fileList = fileUtil.getSubFiles(desPath+File.separator+namePath,fileList);
+		fileList = fileUtil.getSubFiles(desPath,fileList);
 		for (MultipartFile multipartFile : fileList){
 			if(multipartFile.getName().toLowerCase().endsWith(".png") || multipartFile.getName().toLowerCase().endsWith(".jpg")) {
 				String newName = "upload/picture/" + UUID.randomUUID().toString().replaceAll("-", "") + multipartFile.getName().substring(multipartFile.getName().lastIndexOf("."));
@@ -444,9 +525,9 @@
 						.headers(headers)
 						.build());
 
-				String urls = "http://223.82.109.183:2081/zhba/" + newName;
+				String urls = FileConfig.url + "/"+ FileConfig.bucket + "/" + newName;
 				//内网
-				String inUrl = ip + newName;
+				String inUrl = FtpConfig.ip +"/zhba/"+ newName;
 				//取出身份证号,查询用户信息,更新用户信息
 				String pictrueName = multipartFile.getName().substring(0, multipartFile.getName().lastIndexOf("."));
 //				String regex ="([1-9]\\d{5}(18|19|20)\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3}[0-9Xx])|([1-9]\\d{5}\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3})";
@@ -479,12 +560,13 @@
 						"," + "'" + formatStr + "'" +
 						"," + "'" + examPayment.getWorkerId() + "'" +
 						"," + "'" + examPayment.getPaymentStatus() + "'" +
-						"," +"'" + examPayment.getCertificateUrl() + "'" + ")";
-					FtpUtil.sqlFileUpload(s);
+						"," +"'" + inUrl + "'" + ")";
+					//FtpUtil.sqlFileUpload(s);
+					myAsyncService.dataSync(s);
 
 					//文件推送
-					InputStream inputStream = multipartFile.getInputStream();
-					FtpUtil.uploadFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
+//					InputStream inputStream = multipartFile.getInputStream();
+//					FtpUtil.uploadFile(FtpConfig.ftpHost, ftpPort, FtpConfig.ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
 					in.close();
 				}
 			}
@@ -507,10 +589,10 @@
 	@PostMapping("put-files-talk")
 	public R putFilestak(@RequestParam MultipartFile file) throws IOException, ServerException, InsufficientDataException, InternalException, InvalidResponseException, InvalidKeyException, NoSuchAlgorithmException, XmlParserException, ErrorResponseException {
 		//填写你文件上传的地址以及相应信息
-		String url = "http://223.82.109.183:2081";
-		String access = "zhbaadmin";
-		String secret = "zhbapassword";
-		String bucket = "zhba";
+		String url = FileConfig.apiUrl;
+		String access = FileConfig.access;
+		String secret = FileConfig.secret;
+		String bucket = FileConfig.bucket;
 		MinioClient minioClient =
 			MinioClient.builder()
 				.endpoint(url)
@@ -538,10 +620,12 @@
 				in, in.available(), -1)
 				.headers(headers)
 				.build());
-		InputStream inputStream = file.getInputStream();
-		FtpUtil.uploadFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
+
+		//文件推送
+//		InputStream inputStream = file.getInputStream();
+//		FtpUtil.uploadFile(FtpConfig.ftpHost, ftpPort, FtpConfig.ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
 		in.close();
-		String urls = "http://223.82.109.183:2081/zhba/" + newName;
+		String urls = FileConfig.url + "/"+ FileConfig.bucket + "/" + newName;
 		//数据封装
 		Map<String, Object> map = new HashMap<>(2);
 		map.put("name", newName);
@@ -624,9 +708,9 @@
 		}
 		attachService.save(attach);
 		String[] split = bladeFile.getName().split("/");
-		String ip = FtpConstant.ip+"/zhba/upload/picture/";
+		String ip = FtpConfig.ip+"/zhba/upload/picture/";
 		String imgurl = ip + split[2];
-		FtpUtil.uploadFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", split[2], in);
+		FtpUtil.uploadFile(FtpConfig.ftpHost, ftpPort, FtpConfig.ftpUserName, ftpPassword, ftpPath, "/", split[2], in);
 		//数据同步
 		String s1 =
 			"insert into blade_attach(id,tenant_id,link,domain,name,original_name,extension,attach_size,create_user,deptid," +
@@ -674,7 +758,8 @@
 		} else {
 			s1 += ")";
 		}
-		FtpUtil.sqlFileUpload(s1);
+		//FtpUtil.sqlFileUpload(s1);
+		myAsyncService.dataSync(s1);
 		return attach.getId();
 	}
 

--
Gitblit v1.9.3