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

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


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

    @Autowired
    private FtpService ftpService;
284718418@qq.com committed
59 60
    @Autowired
    private DiskFilesService diskFilesService;
61

62 63
    @Autowired
    private SftpConfiguration config;
64 65 66 67


    @ResponseBody
    @PostMapping("/upload")
68
    @ApiOperation(value = "上传普通文件", httpMethod = "POST", notes = "接口发布说明")
69
    public Result<Object> upload(@CurrentUser UserBean userBean, @RequestParam(required = true) MultipartFile[] file,
70
                                 @ApiParam("文件文件夹或共享空间ID") @RequestParam(required = false) Integer catalogueId,HttpServletRequest request) {
翁国栋 committed
71
        if(catalogueId<=0){
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
            DiskCatalogue diskCatalogue = DiskCatalogue.builder().build().selectOne(new QueryWrapper<DiskCatalogue>().select("id")
                    .eq("org_id", userBean.getOrgCode())
                    .eq("delete_flag",0)
                    .eq("create_user_id",userBean.getEmpNum()).orderByAsc("create_time")
            );
            if(StringUtils.isEmpty(diskCatalogue)){
                diskCatalogue = new DiskCatalogue();
                diskCatalogue.setCreateUserId(userBean.getEmpNum());
                diskCatalogue.setOrgId(userBean.getOrgCode());
                diskCatalogue.setParentIds("");
                diskCatalogue.setName("我的文件夹");
                diskCatalogue.setUserName(userBean.getUserInfo().getName());
                diskCatalogue.setType(JxglEnumInterface.DiskCatalogueType.DISK_FILE.getType());
                diskCatalogue.insert();
            }
            catalogueId = diskCatalogue.getId();

            //return ResultUtil.error("上传失败,请选择文件夹");
翁国栋 committed
90
        }
91 92 93 94
        if (file == null || file.length == 0) {
            return ResultUtil.error("上传失败,请选择上传文件");
        }
        DiskFiles diskFiles = new DiskFiles();
95 96 97 98
        diskFiles.setOrgId(userBean.getOrgCode());
        diskFiles.setCreateUserId(userBean.getEmpNum());
        diskFiles.setUploadIp(UserIp.getIpAddr(request));
        diskFiles.setUserName(userBean.getQyzxEmpLogin().getUsername());
99 100
        DiskCatalogueFiles diskCatalogueFiles = new DiskCatalogueFiles();
        DiskFilesLog diskFilesLog = new DiskFilesLog();
101 102
        diskFilesLog.setUserId(userBean.getEmpNum());
        diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
103 104 105
        List<FileInfoDto> imageUrls;
        try {
            //上传文件到服务器
106
            imageUrls = ftpService.uploadFile(file);
107 108 109 110
            for (FileInfoDto dto : imageUrls) {
                //新增资源上传文件
                diskFiles.setFileType(dto.getFileSuffix());
                //"/home/disk/123456.jpg"
111
                diskFiles.setDiskPath(config.getRoot() + config.getTargetPath() + "/" + dto.getFileName());
112 113 114
                diskFiles.setUrlPath(dto.getUrlPath());
                diskFiles.setTitle(dto.getResourceFileName());
                diskFiles.setFileSize(dto.getFileSize());
284718418@qq.com committed
115
                // 显示大小:10KB,5M,2G
116
                diskFiles.setShowSize(FileUtils.getSize(dto.getFileSize()));
117 118 119 120 121 122 123 124 125 126
                diskFiles.insert();

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

                //新增 文件浏览记录
                diskFilesLog.setFilePath(dto.getUrlPath());
                diskFilesLog.setFilesId(diskFiles.getId());
284718418@qq.com committed
127
                diskFilesLog.setFileSize(dto.getFileSize() + "B");
128 129 130 131 132
                diskFilesLog.setTitle(dto.getResourceFileName());
                diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.CREATE_LOG.getType());
                diskFilesLog.insert();

            }
翁国栋 committed
133
            return ResultUtil.data(diskFiles);
134 135 136 137 138
        } catch (Exception e) {
            e.printStackTrace();
        }
        return ResultUtil.error("上传文件失败");
    }
139
    /*@ResponseBody
140 141 142 143 144 145 146 147 148 149 150 151 152
    @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 {
153
            boolean count = ftpService.downloadFile(diskFiles.getDiskPath());
154 155 156 157 158 159 160 161
            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());
162
                diskFilesLog.setUserId(userBean.getEmpNum());
284718418@qq.com committed
163
                diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
164 165 166 167 168 169 170 171
                diskFilesLog.insert();
                return ResultUtil.success();
            }
        } catch (Exception e) {
            e.printStackTrace();
            throw new CustomException("下载文件异常,请联系管理员");
        }
        return ResultUtil.error("下载文件失败");
284718418@qq.com committed
172
    }*/
173 174 175 176 177 178 179 180 181 182 183 184 185
    /**
     * 云盘-文件重命名
     *
     * @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();
186
            /*if (StringUtils.isEmpty(diskFiles) || !diskFiles.getCreateUserId().equals(userBean.getEmpNum())) {
284718418@qq.com committed
187
                return ResultUtil.error("无权限,操作失败!");
188
            }*/
189 190
            entity.setId(diskFiles.getId());
            entity.setTitle(diskFilesParam.getName());
191
            entity.setUpdateUserId(userBean.getEmpNum());
284718418@qq.com committed
192
            entity.setUserName(userBean.getQyzxEmpLogin().getUsername());
193 194 195 196 197 198 199 200 201 202 203 204 205
            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());
206
                diskFilesLog.setUserId(userBean.getEmpNum());
284718418@qq.com committed
207
                diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
208 209 210 211 212 213 214 215 216 217
                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
218

284718418@qq.com committed
219 220 221 222 223 224
    /**
     * 云盘-我的文件空间大小
     *
     * @param userBean
     * @return
     */
225
    @GetMapping(value = "/mycatalogue/{type}")
284718418@qq.com committed
226
    @ApiOperation(value = "我的文件空间大小", httpMethod = "GET", notes = "我的文件空间大小")
227
    public Result<Object> myCatalogue(@PathVariable("type")Integer type,@CurrentUser UserBean userBean) {
284718418@qq.com committed
228
        try {
229
            DiskFileCatalogueDto diskFileCatalogueDto = diskFilesService.getFileCount(userBean,type);
284718418@qq.com committed
230 231 232 233 234 235 236 237
            return ResultUtil.data(diskFileCatalogueDto);
        }catch (Exception e){
            e.printStackTrace();
            throw new CustomException("获取我的文件空间大小异常");
        }
    }

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

284718418@qq.com committed
245 246 247
        if(StringUtils.isEmpty(diskFiles)){
            throw new CustomException("下载失败,文件不存在");
        }
284718418@qq.com committed
248 249
        if(diskFiles.getDeleteFlag() == 1 && StringUtils.isEmpty(type)){
            throw new CustomException("下载失败,该文件已删除");
250
        }*/
251
        InputStream fis = null;
284718418@qq.com committed
252 253 254 255 256 257 258 259
        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");
260
//            filePath = new File(diskFiles.getDiskPath());
284718418@qq.com committed
261
            byte[] buffer = new byte[1024];
262 263
//            fis = new FileInputStream(filePath);
            fis = ftpService.downloadFile(diskFiles.getDiskPath());
284718418@qq.com committed
264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297
            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();
            }
        }
    }

298 299

    @ApiOperation(value = "新增文件查看记录", httpMethod = "GET", notes = "新增文件查看记录")
300 301 302
    @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){
303 304
        DiskFiles diskFiles = DiskFiles.builder().id(fileId).build().selectById();
        DiskFilesLog diskFilesLog = DiskFilesLog.builder().build();
305 306 307 308 309 310
        if(StringUtils.isEmpty(diskFiles)){
            throw new CustomException("查看失败,文件不存在");
        }
        if(diskFiles.getDeleteFlag() == 1 && StringUtils.isEmpty(type)){
            throw new CustomException("查看失败,该文件已删除");
        }
311 312 313 314 315 316 317 318 319 320 321 322
        //新增 文件浏览记录
        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();
    }

323 324 325 326 327 328 329 330 331 332 333 334 335 336 337
    @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
338
}