From e71bd87b3f06a7357ee5142c8f538736e7ef1efa Mon Sep 17 00:00:00 2001 From: qirong <2032486488@qq.com> Date: 星期三, 28 二月 2024 10:00:17 +0800 Subject: [PATCH] 修改 --- ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/service/impl/SysOssServiceImpl.java | 97 +++++++++++++++++++++++++++++++++++++----------- 1 files changed, 74 insertions(+), 23 deletions(-) diff --git a/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/service/impl/SysOssServiceImpl.java b/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/service/impl/SysOssServiceImpl.java index f4ba4b7..345b542 100644 --- a/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/service/impl/SysOssServiceImpl.java +++ b/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/service/impl/SysOssServiceImpl.java @@ -8,7 +8,10 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.fasterxml.jackson.databind.ObjectMapper; +import com.fasterxml.jackson.databind.SerializationFeature; import com.github.therapi.runtimejavadoc.repack.com.eclipsesource.json.Json; +import org.apache.commons.io.IOUtils; +import org.apache.xmlbeans.impl.common.IOUtil; import org.dromara.common.core.constant.CacheNames; import org.dromara.common.core.domain.R; import org.dromara.common.core.domain.model.LoginUser; @@ -24,11 +27,13 @@ import org.dromara.common.oss.core.OssClient; import org.dromara.common.oss.entity.SynchronousRequest; import org.dromara.common.oss.entity.UploadResult; +import org.dromara.common.oss.entity.VideoRequest; import org.dromara.common.oss.enumd.AccessPolicyType; import org.dromara.common.oss.factory.OssFactory; import org.dromara.common.satoken.utils.LoginHelper; import org.dromara.system.domain.SysOss; import org.dromara.system.domain.bo.SysOssBo; +import org.dromara.system.domain.properties.Boundary; import org.dromara.system.domain.vo.SysOssVo; import org.dromara.system.mapper.SysOssMapper; import org.dromara.system.service.ISysOssService; @@ -42,9 +47,10 @@ import org.springframework.stereotype.Service; import org.springframework.web.multipart.MultipartFile; -import java.io.File; -import java.io.IOException; -import java.io.InputStream; +import java.io.*; +import java.net.URLEncoder; +import java.text.ParseException; +import java.text.SimpleDateFormat; import java.util.*; /** @@ -56,6 +62,7 @@ @Service public class SysOssServiceImpl implements ISysOssService, OssService { + private final Boundary boundary; private final SysOssMapper baseMapper; @Override @@ -153,15 +160,57 @@ return buildResultEntity(originalfileName, suffix, storage.getConfigKey(), uploadResult, file); } + @Override + public SysOssVo upload3(VideoRequest request) throws IOException { + + String originalfileName = request.getFileName(); + String suffix = StringUtils.substring(originalfileName, originalfileName.lastIndexOf("."), originalfileName.length()); + OssClient storage = OssFactory.instance(); + UploadResult uploadResult; + try { + uploadResult = storage.uploadSuffix(request.getFile().getBytes(), suffix, request.getFile().getContentType()); + } catch (IOException e) { + throw new ServiceException(e.getMessage()); + } + // 淇濆瓨鏂囦欢淇℃伅 + return buildResultEntity(originalfileName, suffix, storage.getConfigKey(), uploadResult, request.getFile()); + } + /** - * 鍚屾 + * 鍚屾 瀹氭椂鎷夊彇 * @param * @param * @return */ @Override - public SysOssVo upload2(SynchronousRequest request) { - String originalfileName = request.getFile().getOriginalFilename(); + public SysOssVo upload2(SynchronousRequest request) throws ParseException { + String originalfileName = request.getFileName(); + String suffix = StringUtils.substring(originalfileName, originalfileName.lastIndexOf("."), originalfileName.length()); + OssClient storage = OssFactory.instance(); +// String type = request.getFileName().substring(14,request.getFileName().length()); + String type = request.getFile().getContentType(); + UploadResult uploadResult; + try { + uploadResult = storage.uploadSuffix2(request.getFile().getBytes(), request.getPath(), type); + } catch (IOException e) { + throw new ServiceException(e.getMessage()); + } + // 淇濆瓨鏂囦欢淇℃伅 + System.out.println("canshu:" + "," + originalfileName +"," + suffix +"," + storage.getConfigKey() +"," + uploadResult + "," +request.getOssId() + +"," + request.getPassword() +"," + request.getCreateBy() +"," + request.getFileName() +"," + request.getCreateTime()); + return buildResultEntity2(originalfileName, suffix, storage.getConfigKey(), uploadResult,request.getOssId(), + request.getPassword(), "1731588854831022081", request.getFileName(), request.getCreateTime()); + } + + /** + * 鍚屾 瀹氭椂鎷夊彇 + * @param + * @param + * @return + */ + @Override + public SysOssVo upload3(SynchronousRequest request) throws ParseException { + String originalfileName = request.getFileName(); String suffix = StringUtils.substring(originalfileName, originalfileName.lastIndexOf("."), originalfileName.length()); OssClient storage = OssFactory.instance(); UploadResult uploadResult; @@ -171,8 +220,10 @@ throw new ServiceException(e.getMessage()); } // 淇濆瓨鏂囦欢淇℃伅 + System.out.println("canshu:" + "," + originalfileName +"," + suffix +"," + storage.getConfigKey() +"," + uploadResult + "," +request.getOssId() + +"," + request.getPassword() +"," + request.getCreateBy() +"," + request.getFileName() +"," + request.getCreateTime()); return buildResultEntity2(originalfileName, suffix, storage.getConfigKey(), uploadResult,request.getOssId(), - request.getPassword(), request.getCreateBy()); + request.getPassword(), "1731588854831022081", request.getFileName(), request.getCreateTime()); } // @Override @@ -197,12 +248,15 @@ baseMapper.insert(oss); //鎷兼帴鍚屾淇℃伅 SynchronousRequest request = new SynchronousRequest(); + SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); request.setFile(file); - request.setPath(uploadResult.getFilename() + "123"); -// request.setCreateTime(new Date()); + request.setFileName(oss.getOriginalName()); + request.setPath(uploadResult.getFilename()); + request.setCreateTime(format.format(oss.getCreateTime())); request.setPassword(oss.getPassword()); - request.setCreateBy(String.valueOf(oss.getCreateBy())); + request.setCreateBy("1731588854831022081"); request.setOssId(String.valueOf(oss.getOssId())); +// request.setOssId("123890"); post(request); SysOssVo sysOssVo = MapstructUtils.convert(oss, SysOssVo.class); @@ -224,17 +278,19 @@ @NotNull private SysOssVo buildResultEntity2(String originalfileName, String suffix, String configKey, UploadResult uploadResult, String ossId, String password, - String createBy) { + String createBy, String fileName, String createTime) throws ParseException { SysOss oss = new SysOss(); - oss.setOssId(Long.valueOf(ossId.substring(0,ossId.length()-3) + "000")); + SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + oss.setOssId(Long.valueOf(ossId)); oss.setUrl(uploadResult.getUrl()); oss.setFileSuffix(suffix); oss.setFileName(uploadResult.getFilename()); - oss.setOriginalName(originalfileName); + oss.setOriginalName(fileName); oss.setService(configKey); oss.setPassword(password); oss.setCreateTime(new Date()); oss.setCreateBy(Long.valueOf(createBy)); + oss.setCreateTime(format.parse(createTime)); baseMapper.insert(oss); SysOssVo sysOssVo = MapstructUtils.convert(oss, SysOssVo.class); return this.matchingUrl(sysOssVo); @@ -251,13 +307,15 @@ storage.delete(sysOss.getUrl()); if(sysOss.getPassword().equals(password) || password.equals("000000")){ baseMapper.deleteById(sysOss.getOssId()); - HttpUtils.sendDeleteRequest("http://192.168.3.43/resource/synchronization",String.valueOf(sysOss.getOssId())); +// HttpUtils.sendDeleteRequest(boundary.getVideo() + "/resource/synchronization/delete",String.valueOf(sysOss.getOssId())); return true; } return false; } return true; } + + @Override public R viewPasswordById(Long ossId) { @@ -289,16 +347,9 @@ private String post(SynchronousRequest request) throws IOException { HashMap<String, String> headers = new HashMap<>(3); - String requestUrl = "http://192.168.3.43:8080/resource/synchronization/upload"; + String requestUrl = boundary.getVideo() + "/resource/synchronization/upload"; ObjectMapper objectMapper = new ObjectMapper(); - String jsonString = ""; - try { - // 灏咼ava瀵硅薄杞崲涓篔SON瀛楃涓� - jsonString = objectMapper.writeValueAsString(request); - System.out.println(jsonString); - } catch (Exception e) { - e.printStackTrace(); - } + objectMapper.disable(SerializationFeature.FAIL_ON_EMPTY_BEANS); headers.put("content-type", "application/json"); // 鍙戦�乸ost璇锋眰 String resultData = HttpUtils.sendPostRequest(requestUrl, request); -- Gitblit v1.8.0