需修改文件先下载问题和Apk下载问题
This commit is contained in:
parent
21cd70dd4f
commit
2cc11f5e67
@ -167,7 +167,7 @@ public class AppVersionServiceImpl extends DefaultBaseService implements IAppVer
|
||||
Map<String, Object> params = getHashMap(4);
|
||||
params.put("fileId", appVersionPO.getAppFile());
|
||||
params.put("isOpen", false);
|
||||
boolean isDownloadComplete = fileService.downLoadFile(request, response, params, false);
|
||||
boolean isDownloadComplete = fileService.downLoadFile(request, response, params, true);
|
||||
if(isDownloadComplete) {
|
||||
LOG.debug("更新下载次数");
|
||||
appVersionDao.updateDownloadCount(appVersionPO.getAppVersionId());
|
||||
|
@ -178,8 +178,6 @@ public class MinIoFileServiceImpl extends DefaultBaseService implements IMinIoFi
|
||||
if (!isOpen) {
|
||||
// 下载
|
||||
response.setHeader("Content-Disposition", "attachment;fileName=" + URLEncoder.encode(filePO.getFileName(), "UTF-8"));
|
||||
GetObjectArgs getObjectArgs = GetObjectArgs.builder().bucket(filePO.getFileUrl()).object(objectName).build();
|
||||
inputStream = minioClient.getObject(getObjectArgs);
|
||||
} else {
|
||||
// 直接打开
|
||||
response.setHeader("Content-Disposition", "inline;fileName=" + URLEncoder.encode(filePO.getFileName(), "UTF-8"));
|
||||
@ -197,6 +195,7 @@ public class MinIoFileServiceImpl extends DefaultBaseService implements IMinIoFi
|
||||
response.setHeader("max-age", "3600");
|
||||
response.setHeader("Last-Modified", filePO.getGmtModified());
|
||||
}
|
||||
}
|
||||
String rangeString = null;
|
||||
if (canRange && request != null) {
|
||||
rangeString = request.getHeader("Range");
|
||||
@ -221,21 +220,21 @@ public class MinIoFileServiceImpl extends DefaultBaseService implements IMinIoFi
|
||||
return true;
|
||||
}
|
||||
LOG.debug("rangeLength: {}", rangeLength);
|
||||
inputStream = minioClient.getObject(GetObjectArgs.builder().bucket(filePO.getFileUrl()).object(objectName).offset(startRange).length(rangeLength + 1).build());
|
||||
inputStream = minioClient.getObject(GetObjectArgs.builder().bucket(filePO.getFileUrl()).object(objectName).offset(startRange).length(rangeLength).build());
|
||||
} else {
|
||||
inputStream = minioClient.getObject(GetObjectArgs.builder().bucket(filePO.getFileUrl()).object(objectName).build());
|
||||
inputStream = minioClient.getObject(GetObjectArgs.builder().bucket(filePO.getFileUrl()).object(objectName).offset(0L).length(contentLength).build());
|
||||
}
|
||||
if (endRange == contentLength) {
|
||||
isDownloadComplete = true;
|
||||
}
|
||||
}
|
||||
byte[] readBuf = new byte[IFileService.INPUT_STREAM_SIZE];
|
||||
for (int length = 0; (length = inputStream.read(readBuf)) > 0; ) {
|
||||
outputStream.write(readBuf, 0, length);
|
||||
}
|
||||
outputStream.flush();
|
||||
inputStream.close();
|
||||
} catch (ServerException | IOException | ErrorResponseException | InsufficientDataException | InternalException | InvalidKeyException | InvalidResponseException | NoSuchAlgorithmException | XmlParserException e) {
|
||||
} catch (ServerException | IOException | ErrorResponseException | InsufficientDataException | InternalException | InvalidKeyException | InvalidResponseException | NoSuchAlgorithmException |
|
||||
XmlParserException e) {
|
||||
throw new FileException("文件输出异常", e);
|
||||
} finally {
|
||||
if (inputStream != null) {
|
||||
|
Loading…
Reference in New Issue
Block a user