DiskFilesController.java 15.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
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 64 65 66 67 68 69 70 71 72 73 74 75 76

    @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")
77
    @ApiOperation(value = "上传普通文件", httpMethod = "POST", notes = "接口发布说明")
78
    public Result<Object> upload(@CurrentUser UserBean userBean, @RequestParam(required = true) MultipartFile[] file,
79
                                 @ApiParam("文件文件夹或共享空间ID") @RequestParam(required = false) Integer catalogueId,HttpServletRequest request) {
翁国栋 committed
80
        if(catalogueId<=0){
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
            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
99
        }
100 101 102 103
        if (file == null || file.length == 0) {
            return ResultUtil.error("上传失败,请选择上传文件");
        }
        DiskFiles diskFiles = new DiskFiles();
104 105 106 107
        diskFiles.setOrgId(userBean.getOrgCode());
        diskFiles.setCreateUserId(userBean.getEmpNum());
        diskFiles.setUploadIp(UserIp.getIpAddr(request));
        diskFiles.setUserName(userBean.getQyzxEmpLogin().getUsername());
108 109
        DiskCatalogueFiles diskCatalogueFiles = new DiskCatalogueFiles();
        DiskFilesLog diskFilesLog = new DiskFilesLog();
110 111
        diskFilesLog.setUserId(userBean.getEmpNum());
        diskFilesLog.setUserName(userBean.getQyzxEmpLogin().getUsername());
112 113 114 115 116 117 118 119 120 121 122 123
        List<FileInfoDto> imageUrls;
        try {
            //上传文件到服务器
            imageUrls = ftpService.uploadFile(targetPath, file, reservedName);
            for (FileInfoDto dto : imageUrls) {
                //新增资源上传文件
                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
124
                // 显示大小:10KB,5M,2G
125
                diskFiles.setShowSize(FileUtils.getSize(dto.getFileSize()));
126 127 128 129 130 131 132 133 134 135
                diskFiles.insert();

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

                //新增 文件浏览记录
                diskFilesLog.setFilePath(dto.getUrlPath());
                diskFilesLog.setFilesId(diskFiles.getId());
284718418@qq.com committed
136
                diskFilesLog.setFileSize(dto.getFileSize() + "B");
137 138 139 140 141
                diskFilesLog.setTitle(dto.getResourceFileName());
                diskFilesLog.setType(JxglEnumInterface.DiskFilesLogType.CREATE_LOG.getType());
                diskFilesLog.insert();

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

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

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

284718418@qq.com committed
254 255 256
        if(StringUtils.isEmpty(diskFiles)){
            throw new CustomException("下载失败,文件不存在");
        }
284718418@qq.com committed
257 258
        if(diskFiles.getDeleteFlag() == 1 && StringUtils.isEmpty(type)){
            throw new CustomException("下载失败,该文件已删除");
259
        }*/
260
        InputStream fis = null;
284718418@qq.com committed
261 262 263 264 265 266 267 268
        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");
269
//            filePath = new File(diskFiles.getDiskPath());
284718418@qq.com committed
270
            byte[] buffer = new byte[1024];
271 272
//            fis = new FileInputStream(filePath);
            fis = ftpService.downloadFile(diskFiles.getDiskPath());
284718418@qq.com committed
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 298 299 300 301 302 303 304 305 306
            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();
            }
        }
    }

307 308

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

332 333 334 335 336 337 338 339 340 341 342 343 344 345 346
    @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
347
}