需修改文件先下载问题和Apk下载问题

This commit is contained in:
WenG 2022-03-05 09:56:49 +08:00
parent 21cd70dd4f
commit 2cc11f5e67
2 changed files with 32 additions and 33 deletions

View File

@ -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());

View File

@ -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,37 +195,37 @@ 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");
LOG.debug("range: {}", rangeString);
}
String rangeString = null;
if (canRange && request != null) {
rangeString = request.getHeader("Range");
LOG.debug("range: {}", rangeString);
}
long contentLength = Long.valueOf(filePO.getFileSize());
long startRange = 0;
long endRange = contentLength - 1;
LOG.debug("1.startRange: {}, endRange: {}", startRange, endRange);
if (!StringUtils.isBlank(rangeString)) {
response.setContentType("multipart/byteranges");
String[] rangeArray = rangeString.substring(rangeString.indexOf("=") + 1).split("-");
startRange = Long.valueOf(rangeArray[0]);
if (rangeArray.length > 1) {
LOG.debug("2.startRange: {}, endRange: {}", startRange, endRange);
endRange = Long.valueOf(rangeArray[1]);
}
long contentLength = Long.valueOf(filePO.getFileSize());
long startRange = 0;
long endRange = contentLength - 1;
LOG.debug("1.startRange: {}, endRange: {}", startRange, endRange);
if (!StringUtils.isBlank(rangeString)) {
response.setContentType("multipart/byteranges");
String[] rangeArray = rangeString.substring(rangeString.indexOf("=") + 1).split("-");
startRange = Long.valueOf(rangeArray[0]);
if (rangeArray.length > 1) {
LOG.debug("2.startRange: {}, endRange: {}", startRange, endRange);
endRange = Long.valueOf(rangeArray[1]);
}
setRangeHeader(startRange, endRange, response, filePO.getFileId(), contentLength);
long rangeLength = endRange - startRange + 1;
if (rangeLength <= 0) {
// 标记为已完成
return true;
}
LOG.debug("rangeLength: {}", rangeLength);
inputStream = minioClient.getObject(GetObjectArgs.builder().bucket(filePO.getFileUrl()).object(objectName).offset(startRange).length(rangeLength + 1).build());
} else {
inputStream = minioClient.getObject(GetObjectArgs.builder().bucket(filePO.getFileUrl()).object(objectName).build());
}
if (endRange == contentLength) {
isDownloadComplete = true;
setRangeHeader(startRange, endRange, response, filePO.getFileId(), contentLength);
long rangeLength = endRange - startRange + 1;
if (rangeLength <= 0) {
// 标记为已完成
return true;
}
LOG.debug("rangeLength: {}", rangeLength);
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).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; ) {
@ -235,7 +233,8 @@ public class MinIoFileServiceImpl extends DefaultBaseService implements IMinIoFi
}
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) {