From 90f2acaa6c61d5a60822d4fee5a44ec3c5404f67 Mon Sep 17 00:00:00 2001
From: 侯瑞军 <411269194@kidgrow.com>
Date: Wed, 31 Mar 2021 18:52:02 +0800
Subject: [PATCH] Merge branch 'dev' of http://192.168.2.240:7070/r/kidgrow-microservices-platform into dev

---
 kidgrow-business/kidgrow-filecenter/kidgrow-filecenter-biz/src/main/java/com/kidgrow/filecenter/service/impl/AbstractIFileService.java |   78 ++++++++++++++++++++++++++++++++-------
 1 files changed, 64 insertions(+), 14 deletions(-)

diff --git a/kidgrow-business/kidgrow-filecenter/kidgrow-filecenter-biz/src/main/java/com/kidgrow/filecenter/service/impl/AbstractIFileService.java b/kidgrow-business/kidgrow-filecenter/kidgrow-filecenter-biz/src/main/java/com/kidgrow/filecenter/service/impl/AbstractIFileService.java
index 1a547e3..06eb65d 100644
--- a/kidgrow-business/kidgrow-filecenter/kidgrow-filecenter-biz/src/main/java/com/kidgrow/filecenter/service/impl/AbstractIFileService.java
+++ b/kidgrow-business/kidgrow-filecenter/kidgrow-filecenter-biz/src/main/java/com/kidgrow/filecenter/service/impl/AbstractIFileService.java
@@ -9,7 +9,6 @@
 import com.kidgrow.common.model.PageResult;
 import com.kidgrow.common.model.ResultBody;
 import com.kidgrow.common.utils.DateUtil;
-import com.kidgrow.common.utils.MultipartFileUtils;
 import com.kidgrow.common.utils.RandomValueUtils;
 import com.kidgrow.common.utils.StringUtils;
 import com.kidgrow.filecenter.mapper.FileMapper;
@@ -19,11 +18,11 @@
 import lombok.extern.slf4j.Slf4j;
 import net.coobird.thumbnailator.Thumbnails;
 import org.apache.commons.collections4.MapUtils;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.web.multipart.MultipartFile;
 import sun.misc.BASE64Decoder;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
 import sun.misc.BASE64Encoder;
 
 import java.io.*;
@@ -34,8 +33,8 @@
 /**
  * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020<br>
  *
- * @Description: <br>
- * @Project: <br>
+ * @Description: AbstractIFileService 抽取类<br>
+ * @Project: 根据kidgrow.file-server.type 实例化具体对象<br>
  * @CreateDate: Created in 2020/2/18 11:24 <br>
  * @Author: <a href="4345453@kidgrow.com">liuke</a>
  */
@@ -46,6 +45,8 @@
 
     @Value("${kidgrow.file-server.oss.domain}")
     private  String DOMAIN;
+    @Value("${spring.profiles.active}")
+    private String OssPathEn;
     @Override
     public FileInfo upload(MultipartFile file) throws Exception {
         FileInfo fileInfo = FileUtil.getFileInfo(file);
@@ -99,8 +100,8 @@
      * @param fileInfo
      */
     protected abstract void uploadFile(MultipartFile file, FileInfo fileInfo) throws Exception;
-    protected abstract void fileUpLoadOss(FileInfo fileInfo,String newFilePath, InputStream fileStream);
-    protected abstract String FilePath(String imgType,String folderByDate);
+    protected abstract void fileUpLoadOss(FileInfo fileInfo,String newFilePath, InputStream fileStream,String fileFolder);
+    protected abstract String FilePath(String imgType,String folderByDate,String hospitalId,String departmentId);
     protected abstract OSSObject down(String url);
 
     /**
@@ -160,7 +161,7 @@
                 //将生成的文件转换为流
                 InputStream inputStream=new FileInputStream(thuFile);
                 String folderByDate = DateUtil.formatDate(new Date());
-                String filefloder=this.FilePath(imgType,folderByDate);
+                String filefloder=this.FilePath(imgType,folderByDate,null,null);
                 FileInfo newfileInfo=new FileInfo();
                 newfileInfo.setName(newFileName);
                 newfileInfo.setId(IdUtil.fastSimpleUUID());
@@ -171,7 +172,7 @@
                 newfileInfo.setImgType(imgType);
                 newfileInfo.setCreateTime(new Date());
                 //文件上传到oss
-                this.fileUpLoadOss(newfileInfo,filefloder+newFileName,inputStream);
+                this.fileUpLoadOss(newfileInfo,filefloder+newFileName,inputStream,filefloder);
                 inputStream.close();
 //                //删除暂存文件
 //                MultipartFileUtils.delteTempFile(thuFile);
@@ -190,7 +191,7 @@
     }
 
     @Override
-    public FileInfo baseUplaod(String file, String imgType) {
+    public FileInfo baseUplaod(String file, String imgType, String hospitalId, String departmentId) {
         if(file==null||"".equals(file.trim())){
             return null;
         }
@@ -215,7 +216,9 @@
             newfileInfo.setSource("aliyun");
             newfileInfo.setImgType(imgType);
             newfileInfo.setCreateTime(new Date());
-            this.fileUpLoadOss(newfileInfo,"HospitalLogo/"+newFileName,input);
+            String folderByDate =DateUtil.formatDate(new Date());
+            String filePath = FilePath(imgType, folderByDate, hospitalId, departmentId);
+            this.fileUpLoadOss(newfileInfo,filePath+newFileName,input,filePath);
             input.close();
             baseMapper.insert(newfileInfo);
             return newfileInfo;
@@ -228,12 +231,12 @@
     @Override
     public ResultBody baseDownLoad(Map<String, Object> map) throws Exception {
         String urlDiZhi=MapUtils.getString(map,"url");
-        if(!urlDiZhi.contains(DOMAIN)){
+        if(!urlDiZhi.contains(DOMAIN)&&!urlDiZhi.contains(DOMAIN.replace("https","http"))){
             ByteArrayOutputStream outPut = new ByteArrayOutputStream();
             byte[] data = new byte[1024];
             try {
                 // 创建URL
-                URL url = new URL("http://192.168.2.25:8008/123/J-1.jpg");
+                URL url = new URL(urlDiZhi);
                 // 创建链接
                 HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                 conn.setRequestMethod("GET");
@@ -257,7 +260,7 @@
             List<FileInfo> fileInfos = baseMapper.selectByMap(map);
             if (fileInfos.size() > 0) {
                 FileInfo fileInfo = fileInfos.get(0);
-                OSSObject down = this.down(fileInfo.getUrl().replace(DOMAIN, ""));
+                OSSObject down = this.down(fileInfo.getUrl().replace(DOMAIN, "").replace(DOMAIN.replace("https","http"),""));
                 InputStream objectContent = down.getObjectContent();
                 //返回Base64编码过的字节数组字符串
                 byte[] data = null;
@@ -316,5 +319,52 @@
 
     }
 
+    @Override
+    public FileInfo byteUplaod(String fileName, InputStream inputStream,int size) throws IOException {
+        String houzhui=fileName.substring(fileName.lastIndexOf(".")+1);
+        String newFileName= RandomValueUtils.uuid()+"."+houzhui;
+        FileInfo newfileInfo=new FileInfo();
+        newfileInfo.setName(newFileName);
+        newfileInfo.setId(IdUtil.fastSimpleUUID());
+        newfileInfo.setSize(size);
+        newfileInfo.setIsImg(false);
+        newfileInfo.setContentType("byte[]");
+        newfileInfo.setSource("aliyun");
+        newfileInfo.setImgType(houzhui);
+        newfileInfo.setCreateTime(new Date());
+        this.fileUpLoadOss(newfileInfo,"pdf/"+newFileName,inputStream,"pdf/");
+        baseMapper.insert(newfileInfo);
+        inputStream.close();
+        return newfileInfo;
+    }
+
+    @Override
+    public FileInfo feignUploadHosIdAndDepId(MultipartFile file, String imgType, String hospitalId, String departmentId) throws Exception {
+        List<String> lassStr= Arrays.asList("png","bmp","dib","gif","jfif","jpe","jpeg","jpg","tif","tiff","ico");
+        String suffix=file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
+        if(!lassStr.contains(suffix.toLowerCase())){
+            return null;
+        }
+        String name = file.getOriginalFilename();
+        String fileName= UUID.randomUUID().toString().replaceAll("-","");
+        //image/jpeg;base64
+        String newFileName=fileName+name.substring(name.lastIndexOf("."));
+        FileInfo newfileInfo=new FileInfo();
+        newfileInfo.setName(newFileName);
+        newfileInfo.setId(IdUtil.fastSimpleUUID());
+        newfileInfo.setSize(file.getSize());
+        newfileInfo.setIsImg(true);
+        newfileInfo.setContentType("image/jpeg");
+        newfileInfo.setSource("aliyun");
+        newfileInfo.setImgType(imgType);
+        newfileInfo.setCreateTime(new Date());
+        String folderByDate =DateUtil.formatDate(new Date());
+        String filePath = FilePath(imgType, folderByDate, hospitalId, departmentId);
+        InputStream inputStream = file.getInputStream();
+        this.fileUpLoadOss(newfileInfo,filePath+newFileName,inputStream,filePath);
+        inputStream.close();
+        baseMapper.insert(newfileInfo);
+        return newfileInfo;
+    }
 }
 

--
Gitblit v1.8.0