DiskFilesController.java 14.8 KB
Newer Older
284718418@qq.com committed
1 2
package cn.timer.api.controller.disk;

3
import cn.timer.api.bean.disk.DiskCatalogue;
4 5 6 7 8 9
import cn.timer.api.bean.disk.DiskCatalogueFiles;
import cn.timer.api.bean.disk.DiskFiles;
import cn.timer.api.bean.disk.DiskFilesLog;
import cn.timer.api.config.annotation.CurrentUser;
import cn.timer.api.config.annotation.UserBean;
import cn.timer.api.config.enuminterface.JxglEnumInterface;
10
import cn.timer.api.config.exception.CustomException;
11
import cn.timer.api.config.sftp.SftpConfiguration;
284718418@qq.com committed
12 13
import cn.timer.api.controller.disk.sevice.DiskFilesService;
import cn.timer.api.dto.disk.*;
14
import cn.timer.api.service.FtpService;
15
import cn.timer.api.utils.FileUtils;
16 17
import cn.timer.api.utils.Result;
import cn.timer.api.utils.ResultUtil;
284718418@qq.com committed
18 19
import cn.timer.api.utils.UserIp;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
20
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
284718418@qq.com committed
21
import io.swagger.annotations.Api;
22
import io.swagger.annotations.ApiOperation;
23
import io.swagger.annotations.ApiParam;
24
import org.springframework.beans.BeanUtils;
25 26
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
284718418@qq.com committed
27
import org.springframework.util.CollectionUtils;
28
import org.springframework.util.StringUtils;
29 30 31
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
284718418@qq.com committed
32

284718418@qq.com committed
33
import javax.servlet.http.HttpServletRequest;
34
import javax.servlet.http.HttpServletResponse;
284718418@qq.com committed
35
import javax.transaction.Transactional;
36
import java.io.*;
284718418@qq.com committed
37 38
import java.util.ArrayList;
import java.util.HashMap;
39
import java.util.List;
284718418@qq.com committed
40
import java.util.Map;
284718418@qq.com committed
41 42 43 44


/**
 * 云盘-资源上传文件表
45
 *
284718418@qq.com committed
46 47 48 49 50 51 52
 * @author wuqingjun
 * @email 284718418@qq.com
 * @date 2021-12-27 10:05:49
 */
@Api(tags = "云盘")
@Transactional(rollbackOn = Exception.class)
@RestController
53 54 55 56 57
@RequestMapping("/disk")
public class DiskFilesController {

    @Autowired
    private FtpService ftpService;
284718418@qq.com committed
58 59
    @Autowired
    private DiskFilesService diskFilesService;
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75

    @Value("${sftp.client.root}")
    private String root;

    @Value("${sftp.client.targetPath}")
    private String targetPath;

    @Value("${sftp.client.reservedName}")
    private boolean reservedName;

    @Value("${sftp.client.serverUrl}")
    private String serverUrl;


    @ResponseBody
    @PostMapping("/upload")
76
    @ApiOperation(value = "上传普通文件", httpMethod = "POST", notes = "接口发布说明")
77
    public Result<Object> upload(@CurrentUser UserBean userBean, @RequestParam(required = true) MultipartFile[] file,
284718418@qq.com committed
78
                                 @ApiParam("文件文件夹或共享空间ID") @RequestParam(required = true) Integer catalogueId,HttpServletRequest request) {
翁国栋 committed
79 80 81
        if(catalogueId<=0){
            return ResultUtil.error("上传失败,请选择文件夹");
        }
82 83 84 85 86 87 88 89 90 91 92 93
        if (file == null || file.length == 0) {
            return ResultUtil.error("上传失败,请选择上传文件");
        }
        DiskFiles diskFiles = new DiskFiles();
        DiskCatalogueFiles diskCatalogueFiles = new DiskCatalogueFiles();
        DiskFilesLog diskFilesLog = new DiskFilesLog();
        List<FileInfoDto> imageUrls;
        try {
            //上传文件到服务器
            imageUrls = ftpService.uploadFile(targetPath, file, reservedName);
            for (FileInfoDto dto : imageUrls) {
                //新增资源上传文件
94
                diskFiles.setCreateUserId(userBean.getEmpNum());
95 96 97 98 99 100
                diskFiles.setFileType(dto.getFileSuffix());
                //"/home/disk/123456.jpg"
                diskFiles.setDiskPath(root + targetPath + "/" + dto.getFileName());
                diskFiles.setUrlPath(dto.getUrlPath());
                diskFiles.setTitle(dto.getResourceFileName());
                diskFiles.setFileSize(dto.getFileSize());
284718418@qq.com committed
101
                // 显示大小:10KB,5M,2G
102
                diskFiles.setShowSize(FileUtils.getSize(dto.getFileSize()));
284718418@qq.com committed
103 104
                diskFiles.setUserName(userBean.getQyzxEmpLogin().getUsername());
                diskFiles.setUploadIp(UserIp.getIpAddr(request));
105 106 107 108 109 110 111 112 113 114
                diskFiles.insert();

                //新增中间关系
                diskCatalogueFiles.setCatalogueId(catalogueId);
                diskCatalogueFiles.setFilesId(diskFiles.getId());
                diskCatalogueFiles.insert();

                //新增 文件浏览记录
                diskFilesLog.setFilePath(dto.getUrlPath());
                diskFilesLog.setFilesId(diskFiles.getId());
284718418@qq.com committed
115
                diskFilesLog.setFileSize(dto.getFileSize() + "B");
116 117
                diskFilesLog.setTitle(dto.getResourceFileName());
                diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.CREATE_LOG.getType());
118
                diskFilesLog.setUserId(userBean.getEmpNum());
284718418@qq.com committed
119
                diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
120 121 122
                diskFilesLog.insert();

            }
翁国栋 committed
123
            return ResultUtil.data(diskFiles);
124 125 126 127 128
        } catch (Exception e) {
            e.printStackTrace();
        }
        return ResultUtil.error("上传文件失败");
    }
129
    /*@ResponseBody
130 131 132 133 134 135 136 137 138 139 140 141 142
    @GetMapping("/download")
    @ApiOperation(value = "下载普通文件", httpMethod = "POST", notes = "接口发布说明")
    public Result<Object> download(@CurrentUser UserBean userBean,
                                 @ApiParam("文件ID") @RequestParam(required = true) Integer fileId,
                                   @ApiParam("本地保存目录") @RequestParam(required = true) String localPath) {
        if (fileId == null || fileId <= 0) {
            return ResultUtil.error("下载失败,请选择文件下载");
        }
        DiskFiles diskFiles = DiskFiles.builder().id(fileId).build().selectById();
        if(StringUtils.isEmpty(diskFiles)){
            return ResultUtil.error("下载失败,文件不存在");
        }
        try {
143
            boolean count = ftpService.downloadFile(diskFiles.getDiskPath());
144 145 146 147 148 149 150 151
            if(count){
                DiskFilesLog diskFilesLog = new DiskFilesLog();
                //新增 文件浏览记录
                diskFilesLog.setFilePath(diskFiles.getUrlPath());
                diskFilesLog.setFilesId(diskFiles.getId());
                diskFilesLog.setFileSize(diskFiles.getFileSize() + "B");
                diskFilesLog.setTitle(diskFiles.getTitle());
                diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.DOWN_LOAD_LOG.getType());
152
                diskFilesLog.setUserId(userBean.getEmpNum());
284718418@qq.com committed
153
                diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
154 155 156 157 158 159 160 161
                diskFilesLog.insert();
                return ResultUtil.success();
            }
        } catch (Exception e) {
            e.printStackTrace();
            throw new CustomException("下载文件异常,请联系管理员");
        }
        return ResultUtil.error("下载文件失败");
284718418@qq.com committed
162
    }*/
163 164 165 166 167 168 169 170 171 172 173 174 175
    /**
     * 云盘-文件重命名
     *
     * @param userBean
     * @return
     */
    @ResponseBody
    @PostMapping(value = "/file_name")
    @ApiOperation(value = "文件重命名", httpMethod = "POST", notes = "文件重命名")
    public Result<Object> updateFileName(@CurrentUser UserBean userBean, @Validated @RequestBody DiskFilesParam diskFilesParam) {
        try{
            DiskFiles entity = new DiskFiles();
            DiskFiles diskFiles = DiskFiles.builder().id(diskFilesParam.getId()).build().selectById();
176
            /*if (StringUtils.isEmpty(diskFiles) || !diskFiles.getCreateUserId().equals(userBean.getEmpNum())) {
284718418@qq.com committed
177
                return ResultUtil.error("无权限,操作失败!");
178
            }*/
179 180
            entity.setId(diskFiles.getId());
            entity.setTitle(diskFilesParam.getName());
181
            entity.setUpdateUserId(userBean.getEmpNum());
284718418@qq.com committed
182
            entity.setUserName(userBean.getQyzxEmpLogin().getUsername());
183 184 185 186 187 188 189 190 191 192 193 194 195
            DiskFilesLog diskFilesLog = new DiskFilesLog();
            diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.UPDATE_LOG.getType());
            if(!StringUtils.isEmpty(diskFilesParam.getDeleteFlag())){
                entity.setDeleteFlag(1);
                diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.DELETE_LOG.getType());
            }
            Boolean count = entity.updateById();
            if (count) {
                //新增 文件浏览记录
                diskFilesLog.setFilePath(diskFiles.getUrlPath());
                diskFilesLog.setFilesId(diskFiles.getId());
                diskFilesLog.setFileSize(diskFiles.getFileSize() + "B");
                diskFilesLog.setTitle(diskFiles.getTitle());
196
                diskFilesLog.setUserId(userBean.getEmpNum());
284718418@qq.com committed
197
                diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
198 199 200 201 202 203 204 205 206 207
                diskFilesLog.insert();
                return ResultUtil.data(StringUtils.isEmpty(diskFilesParam.getDeleteFlag())?"文件重命名成功":"删除文件成功");
            } else {
                return ResultUtil.error(StringUtils.isEmpty(diskFilesParam.getDeleteFlag())?"文件重命名失败":"删除文件失败");
            }
        }catch (Exception e){
            e.printStackTrace();
            throw new CustomException(StringUtils.isEmpty(diskFilesParam.getDeleteFlag())?"文件重命名异常":"删除文件异常");
        }
    }
284718418@qq.com committed
208

284718418@qq.com committed
209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227
    /**
     * 云盘-我的文件空间大小
     *
     * @param userBean
     * @return
     */
    @GetMapping(value = "/mycatalogue")
    @ApiOperation(value = "我的文件空间大小", httpMethod = "GET", notes = "我的文件空间大小")
    public Result<Object> myCatalogue(@CurrentUser UserBean userBean) {
        try {
            DiskFileCatalogueDto diskFileCatalogueDto = diskFilesService.getFileCount(userBean.getEmpNum());
            return ResultUtil.data(diskFileCatalogueDto);
        }catch (Exception e){
            e.printStackTrace();
            throw new CustomException("获取我的文件空间大小异常");
        }
    }

    @GetMapping(value = "/exportContract")
284718418@qq.com committed
228 229
    public void exportContract(@CurrentUser UserBean userBean, @ApiParam("文件ID") @RequestParam(required = true) Integer fileId,
                               @ApiParam("下载通道默认不传:我收到的列表下载传type=1") @RequestParam(required = false) Integer type, HttpServletResponse resp) {
230 231
        DiskFiles diskFiles = DiskFiles.builder().id(fileId).build().selectById();
        /*if (fileId == null || fileId <= 0) {
284718418@qq.com committed
232 233
            throw new CustomException("下载失败,请选择文件下载");
        }
234

284718418@qq.com committed
235 236 237
        if(StringUtils.isEmpty(diskFiles)){
            throw new CustomException("下载失败,文件不存在");
        }
284718418@qq.com committed
238 239
        if(diskFiles.getDeleteFlag() == 1 && StringUtils.isEmpty(type)){
            throw new CustomException("下载失败,该文件已删除");
240
        }*/
241
        InputStream fis = null;
284718418@qq.com committed
242 243 244 245 246 247 248 249
        BufferedInputStream bis = null;
        OutputStream os;
        File filePath = null;
        try {
            String name = diskFiles.getTitle()+diskFiles.getFileType();
            resp.setContentType("application/octet-stream");
            resp.setHeader("content-disposition", "attachment; filename=" + new String(name.getBytes("UTF8"), "ISO-8859-1"));
            resp.setCharacterEncoding("UTF-8");
250
//            filePath = new File(diskFiles.getDiskPath());
284718418@qq.com committed
251
            byte[] buffer = new byte[1024];
252 253
//            fis = new FileInputStream(filePath);
            fis = ftpService.downloadFile(diskFiles.getDiskPath());
284718418@qq.com committed
254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287
            bis = new BufferedInputStream(fis);
            os = resp.getOutputStream();
            int i = bis.read(buffer);
            while (i != -1) {
                os.write(buffer, 0, i);
                i = bis.read(buffer);
            }
            os.flush();
            DiskFilesLog diskFilesLog = DiskFilesLog.builder().build();
            //新增 文件浏览记录
            diskFilesLog.setFilePath(diskFiles.getUrlPath());
            diskFilesLog.setFilesId(diskFiles.getId());
            diskFilesLog.setFileSize(diskFiles.getFileSize() + "B");
            diskFilesLog.setTitle(diskFiles.getTitle());
            diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.DOWN_LOAD_LOG.getType());
            diskFilesLog.setUserId(userBean.getEmpNum());
            diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
            diskFilesLog.insert();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                bis.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            try {
                fis.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

288 289

    @ApiOperation(value = "新增文件查看记录", httpMethod = "GET", notes = "新增文件查看记录")
290 291 292
    @GetMapping(value = "/add_look_log")
    public Result<Object> lookLog(@CurrentUser UserBean userBean,@ApiParam("文件ID") @RequestParam(required = true) Integer fileId,
                                  @ApiParam("默认不传,我收到的列表查看传type=1") @RequestParam(required = false) Integer type){
293 294
        DiskFiles diskFiles = DiskFiles.builder().id(fileId).build().selectById();
        DiskFilesLog diskFilesLog = DiskFilesLog.builder().build();
295 296 297 298 299 300
        if(StringUtils.isEmpty(diskFiles)){
            throw new CustomException("查看失败,文件不存在");
        }
        if(diskFiles.getDeleteFlag() == 1 && StringUtils.isEmpty(type)){
            throw new CustomException("查看失败,该文件已删除");
        }
301 302 303 304 305 306 307 308 309 310 311 312
        //新增 文件浏览记录
        diskFilesLog.setFilePath(diskFiles.getUrlPath());
        diskFilesLog.setFilesId(diskFiles.getId());
        diskFilesLog.setFileSize(diskFiles.getFileSize() + "B");
        diskFilesLog.setTitle(diskFiles.getTitle());
        diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.LOOK_LOG.getType());
        diskFilesLog.setUserId(userBean.getEmpNum());
        diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
        diskFilesLog.insert();
        return ResultUtil.success();
    }

313 314 315 316 317 318 319 320 321 322 323 324 325 326 327
    @ApiOperation(value = "查询文件是否存在", httpMethod = "GET", notes = "查询文件是否存在")
    @GetMapping(value = "/query_file_isExist")
    public Result<Object> queryFileIsExist(@CurrentUser UserBean userBean,@ApiParam("文件ID") @RequestParam(required = true) Integer fileId,
                                  @ApiParam("默认不传,我收到的列表查询传type=1") @RequestParam(required = false) Integer type){
        DiskFiles diskFiles = DiskFiles.builder().id(fileId).build().selectById();
        DiskFilesLog diskFilesLog = DiskFilesLog.builder().build();
        if(StringUtils.isEmpty(diskFiles)){
            throw new CustomException("文件不存在");
        }
        if(diskFiles.getDeleteFlag() == 1 && StringUtils.isEmpty(type)){
            throw new CustomException("该文件已删除");
        }
        return ResultUtil.success();
    }

284718418@qq.com committed
328
}