123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310 |
- package com.fdkankan.fusion.service.impl;
- import cn.hutool.core.io.FileUtil;
- import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
- import com.fdkankan.fusion.common.OssPath;
- import com.fdkankan.fusion.common.ResultCode;
- import com.fdkankan.fusion.common.ResultData;
- import com.fdkankan.fusion.common.enums.FileTypeEnum;
- import com.fdkankan.fusion.common.util.FileWriterUtil;
- import com.fdkankan.fusion.common.util.OBJToGLBUtil;
- import com.fdkankan.fusion.common.util.ShellUtil;
- import com.fdkankan.fusion.common.util.LocalToOssUtil;
- import com.fdkankan.fusion.config.CacheUtil;
- import com.fdkankan.fusion.entity.CommonUpload;
- import com.fdkankan.fusion.entity.DictFile;
- import com.fdkankan.fusion.exception.BusinessException;
- import com.fdkankan.fusion.mapper.ICommonUploadMapper;
- import com.fdkankan.fusion.mq.consumer.OsgbToB3dmConsumer;
- import com.fdkankan.fusion.service.ICommonUploadService;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.fdkankan.fusion.service.IDictFileService;
- import lombok.extern.slf4j.Slf4j;
- import org.apache.commons.lang3.StringUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.stereotype.Service;
- import org.springframework.web.multipart.MultipartFile;
- import java.io.File;
- import java.util.ArrayList;
- import java.util.HashMap;
- import java.util.List;
- import java.util.UUID;
- /**
- * <p>
- * 服务实现类
- * </p>
- *
- * @author
- * @since 2025-02-10
- */
- @Service
- @Slf4j
- public class CommonUploadServiceImpl extends ServiceImpl<ICommonUploadMapper, CommonUpload> implements ICommonUploadService {
- @Autowired
- ICommonUploadService commonUploadService;
- @Autowired
- IDictFileService dictFileService;
- @Autowired
- LocalToOssUtil localToOssUtil;
- @Value("${upload.query-path}")
- private String ossUrlPrefix;
-
- @Override
- public ResultData uploadFileNew( Integer dictId,MultipartFile file) {
- if( file.isEmpty() ){
- throw new BusinessException(ResultCode.UPLOAD_ERROR);
- }
- File tempFile = null;
- try {
- String uuid = UUID.randomUUID().toString().replace("-","");
- String name = file.getOriginalFilename();
- String extName = name.substring(name.lastIndexOf(".")).toLowerCase();
- String ossPath = String.format(OssPath.MANAGE_FILE_PATH, uuid + extName);
- tempFile = new File(OssPath.localPath + ossPath);
- if(!tempFile.getParentFile().exists()){
- tempFile.getParentFile().mkdirs();
- }
- file.transferTo(tempFile);
- if(extName.equals(".zip")){
- FileWriterUtil.checkSpace(file.getSize(),3.0);
- return uploadModelZip(name.replace(extName, ""),tempFile,dictId);
- }
- //localToOssUtil.uploadOss(tempFile.getPath(), ossPath);
- //String url = this.ossUrlPrefix + ossPath;
- FileWriterUtil.checkSpace(file.getSize(),1.1);
- String url = CacheUtil.mapping + ossPath;
- FileTypeEnum fileTypeEnum = FileTypeEnum.getByType(extName.replace(".", ""));
- if(fileTypeEnum == null){
- throw new BusinessException(ResultCode.FILE_TYPE_ERROR2);
- }
- String format = extName.replace(".", "");
- CommonUpload commonUpload = commonUploadService.add(name.replace(extName, ""), url, String.valueOf(file.getSize()), uuid, fileTypeEnum, format,format,1,tempFile.getPath(),dictId);
- return ResultData.ok(commonUpload);
- }catch ( BusinessException e){
- log.info("upload-file-error:{}",e);
- throw e;
- }catch (Exception e){
- log.info("upload-file-error:{}",e);
- throw new BusinessException(ResultCode.UPLOAD_ERROR);
- }
- }
- private ResultData uploadModelZip(String oldName,File file,Integer dictId) {
- String ossZipPath = String.format(OssPath.MANAGE_MODEL_FILE_PATH, UUID.randomUUID().toString().replace("-", ""));
- String unzipPath = CacheUtil.basePath + ossZipPath;
- ShellUtil.unZip(file.getPath(),unzipPath);
- try {
- Thread.sleep(1000L);
- FileUtil.del(file.getPath());
- }catch (Exception e){
- log.info("删除文件失败:{}",e);
- }
- //FileUtil.copyContent(file,new File(unzipPath),true);
- File unZipFile = new File(unzipPath);
- if(!unZipFile.exists() || !unZipFile.isDirectory() ){
- throw new BusinessException(ResultCode.UNZIP_ERROR);
- }
- List<File> fileList = new ArrayList<>();
- FileWriterUtil.getCanRunList(fileList,unZipFile);
- if(fileList.size() <=0){
- throw new BusinessException(ResultCode.UPLOAD_FILE_ERROR);
- }
- File modelFile = fileList.get(0);
- if(FileWriterUtil.isChinese(modelFile.getName())){
- throw new BusinessException(ResultCode.FILE_TYPE_ERROR23);
- }
- if(FileWriterUtil.isChinese(modelFile.getPath())){
- throw new BusinessException(ResultCode.FILE_TYPE_ERROR23);
- }
- String modelFileFormat = modelFile.getName().split("\\.")[1].toLowerCase();
- String url = null;
- String resultFormat = modelFileFormat;
- switch (modelFileFormat){
- case "obj" : resultFormat = "obj";
- url = uploadObjOss(ossZipPath,modelFile);break;
- case "laz" : url = uploadLazOss(ossZipPath,modelFile); break;
- case "shp" : url = uploadOss(ossZipPath,modelFile); break;
- case "b3dm" : url = uploadB3dm(ossZipPath,modelFile); break;
- case "las" :
- case "ply" : url = uploadLasOrPly(ossZipPath,modelFile);break;
- case "osgb":
- resultFormat = "b3dm";
- break;
- default: break;
- }
- FileTypeEnum fileTypeEnum = FileTypeEnum.getByType(modelFileFormat);
- if(fileTypeEnum == null){
- throw new BusinessException(ResultCode.FILE_TYPE_ERROR2);
- }
- Integer status = StringUtils.isNotBlank(url) ?1:-1;
- url = StringUtils.isNotBlank(url) ?CacheUtil.mapping + url:null;
- CommonUpload commonUpload = commonUploadService.add(oldName,url, String.valueOf(getDirectorySize(unZipFile)),
- null, fileTypeEnum, modelFileFormat,resultFormat,status,unZipFile.getPath(),dictId);
- if("osgb".equals(modelFileFormat)){
- commonUploadService.updateStatus(commonUpload.getId(),0);
- commonUpload.setStatus(0);
- uploadOsgb(commonUpload.getId()) ;
- }
- return ResultData.ok(commonUpload);
- }
- private String uploadObjOss(String unzipPath, File modelFile) {
- OBJToGLBUtil.checkObj(modelFile.getPath());
- //String localGlbPath = modelFile.getPath().replace(".obj",".glb");
- //OBJToGLBUtil.objToGlb2(modelFile.getPath(),localGlbPath);
- // File file = new File(localGlbPath);
- // if(!file.exists()){
- // throw new BusinessException(ResultCode.UPLOAD_FILE_ERROR);
- // }
- return unzipPath +File.separator+modelFile.getName();
- }
- private String uploadB3dm(String unzipPath, File modelFile) {
- String b3dmJsonPath = FileWriterUtil.checkB3dmTileset(new File(CacheUtil.basePath + unzipPath));
- if(b3dmJsonPath == null){
- throw new BusinessException(ResultCode.UPLOAD_FILE_OBJ_ERROR);
- }
- //uploadOss(unzipPath,modelFile);
- File file = new File(b3dmJsonPath);
- if(!file.exists()){
- throw new BusinessException(ResultCode.UPLOAD_FILE_ERROR);
- }
- return unzipPath +File.separator +file.getName();
- }
- @Autowired
- OsgbToB3dmConsumer osgbToB3dmConsumer;
- private void uploadOsgb(Integer uploadId) {
- //osgbToB3dmConsumer.consumerQueue(CacheUtil.basePath + unzipPath);
- osgbToB3dmConsumer.consumerQueue(uploadId);
- }
- private String uploadLazOss(String unzipPath,File modelFile) {
- if(!modelFile.exists()){
- throw new BusinessException(ResultCode.UPLOAD_FILE_ERROR);
- }
- return unzipPath ;
- // return modelFile.getParentFile().getPath();
- }
- private String uploadOss(String unzipPath,File modelFile) {
- if(!modelFile.exists()){
- throw new BusinessException(ResultCode.UPLOAD_FILE_ERROR);
- }
- return unzipPath;
- // return modelFile.getPath();
- }
- private String uploadLasOrPly(String unzipPath ,File modelFile) {
- File mntFile = OBJToGLBUtil.lasOrPlyToBin(modelFile);
- File file = new File(mntFile.getPath() + "/webcloud/cloud.js");
- if(!file.exists()){
- throw new BusinessException(ResultCode.UPLOAD_FILE_ERROR);
- }
- return unzipPath + File.separator +"webcloud";
- // return mntFile.getPath()+ File.separator +"webcloud";
- }
- @Override
- public CommonUpload add(String fileName, String url, String fileSize, String uuid, FileTypeEnum fileTypeEnum, String resultFormat,String replace1, Integer status, String unzipPath, Integer dictId) {
- CommonUpload upload = new CommonUpload();
- upload.setFileName(fileName);
- upload.setFileUrl(url);
- upload.setFileSize(fileSize);
- upload.setNewFileName(uuid);
- upload.setFileType(fileTypeEnum.getCode());
- upload.setFileTypeStr(fileTypeEnum.getMsg());
- upload.setFileFormat(resultFormat);
- upload.setResultFileFormat(replace1);
- upload.setStatus(status);
- upload.setUnzipPath(unzipPath);
- this.save(upload);
- DictFile dictFile = new DictFile();
- dictFile.setName(fileName);
- dictFile.setTypeKey("media-library");
- dictFile.setUploadId(upload.getId());
- dictFile.setDictId(dictId);
- dictFileService.saveOrUpdate(dictFile);
- return upload;
- }
- @Override
- public void updateByPath(Integer uploadId, String url,String unzipPath) {
- LambdaUpdateWrapper<CommonUpload> wrapper = new LambdaUpdateWrapper<>();
- wrapper.eq(CommonUpload::getId,uploadId);
- wrapper.set(CommonUpload::getStatus,1);
- wrapper.set(CommonUpload::getFileUrl,url);
- wrapper.set(CommonUpload::getUnzipPath,unzipPath);
- this.update(wrapper);
- }
- @Override
- public void updateStatus(Integer uploadId,Integer status) {
- LambdaUpdateWrapper<CommonUpload> wrapper = new LambdaUpdateWrapper<>();
- wrapper.eq(CommonUpload::getId,uploadId);
- wrapper.set(CommonUpload::getStatus,status);
- this.update(wrapper);
- }
- @Override
- public void updateByPath(Integer uploadId, String url,String wgs84 ,String gcj02,String unzipPath) {
- LambdaUpdateWrapper<CommonUpload> wrapper = new LambdaUpdateWrapper<>();
- wrapper.eq(CommonUpload::getId,uploadId);
- wrapper.set(CommonUpload::getStatus,1);
- wrapper.set(CommonUpload::getFileUrl,url);
- wrapper.set(CommonUpload::getWgs84,wgs84);
- wrapper.set(CommonUpload::getGcj02,gcj02);
- wrapper.set(CommonUpload::getUnzipPath,unzipPath);
- this.update(wrapper);
- }
- public static long getDirectorySize(File directory) {
- long size = 0;
- try {
- File[] files = directory.listFiles();
- if (files != null) {
- for (File file : files) {
- if (file.isFile()) {
- size += file.length();
- } else if (file.isDirectory()) {
- size += getDirectorySize(file);
- }
- }
- }
- }catch (Exception e){
- }
- return size;
- }
- @Override
- public List<CommonUpload> getDelData() {
- return this.getBaseMapper().getDelData();
- }
- @Override
- public void delByIds(List<Integer> ids) {
- this.getBaseMapper().delByIds(ids);
- }
- }
|