优化、精简代码。使用 @GetMapping、@PostMapping 替换 @RequestMapping

pull/316/head
kl 2022-07-25 17:26:02 +08:00 committed by kl
parent 6efe15788c
commit b099d52520
7 changed files with 86 additions and 80 deletions

View File

@ -48,8 +48,7 @@ public class SimTextFilePreviewImpl implements FilePreview {
private String textData(String baseUrll) throws IOException { private String textData(String baseUrll) throws IOException {
File file = new File(baseUrll); File file = new File(baseUrll);
if(!file.exists() || file.length() == 0) { if(!file.exists() || file.length() == 0) {
String line=""; return "";
return line;
}else { }else {
String charset = EncodingDetects.getJavaEncode(baseUrll); String charset = EncodingDetects.getJavaEncode(baseUrll);
System.out.println(charset); System.out.println(charset);

View File

@ -8,6 +8,8 @@ import cn.keking.utils.ConvertPicUtil;
import cn.keking.utils.DownloadUtils; import cn.keking.utils.DownloadUtils;
import cn.keking.utils.WebUtils; import cn.keking.utils.WebUtils;
import cn.keking.web.filter.BaseUrlFilter; import cn.keking.web.filter.BaseUrlFilter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.ui.Model; import org.springframework.ui.Model;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
@ -18,12 +20,15 @@ import java.util.List;
/** /**
* tiff * tiff
*
* @author kl (http://kailing.pub) * @author kl (http://kailing.pub)
* @since 2021/2/8 * @since 2021/2/8
*/ */
@Service @Service
public class TiffFilePreviewImpl implements FilePreview { public class TiffFilePreviewImpl implements FilePreview {
private final static Logger logger = LoggerFactory.getLogger(TiffFilePreviewImpl.class);
private final PictureFilePreviewImpl pictureFilePreview; private final PictureFilePreviewImpl pictureFilePreview;
private static final String INITIALIZE_MEMORY_SIZE = "initializeMemorySize"; private static final String INITIALIZE_MEMORY_SIZE = "initializeMemorySize";
//默认初始化 50MB 内存 //默认初始化 50MB 内存
@ -43,25 +48,25 @@ public class TiffFilePreviewImpl implements FilePreview {
tifPreviewType = tifOnLinePreviewType; tifPreviewType = tifOnLinePreviewType;
} }
if("tif".equalsIgnoreCase(tifPreviewType)){ if ("tif".equalsIgnoreCase(tifPreviewType)) {
pictureFilePreview.filePreviewHandle(url,model,fileAttribute); pictureFilePreview.filePreviewHandle(url, model, fileAttribute);
String fileSize = WebUtils.getUrlParameterReg(url,INITIALIZE_MEMORY_SIZE); String fileSize = WebUtils.getUrlParameterReg(url, INITIALIZE_MEMORY_SIZE);
if(StringUtils.hasText(fileSize)){ if (StringUtils.hasText(fileSize)) {
model.addAttribute(INITIALIZE_MEMORY_SIZE,fileSize); model.addAttribute(INITIALIZE_MEMORY_SIZE, fileSize);
}else { } else {
model.addAttribute(INITIALIZE_MEMORY_SIZE,Long.toString(INITIALIZE_MEMORY_SIZE_VALUE_DEFAULT)); model.addAttribute(INITIALIZE_MEMORY_SIZE, Long.toString(INITIALIZE_MEMORY_SIZE_VALUE_DEFAULT));
} }
return TIFF_FILE_PREVIEW_PAGE; return TIFF_FILE_PREVIEW_PAGE;
}else if("jpg".equalsIgnoreCase(tifPreviewType) || "pdf".equalsIgnoreCase(tifPreviewType)){ } else if ("jpg".equalsIgnoreCase(tifPreviewType) || "pdf".equalsIgnoreCase(tifPreviewType)) {
String inputFileName = url.substring(url.lastIndexOf("/") + 1); String inputFileName = url.substring(url.lastIndexOf("/") + 1);
String inputFileNamePrefix = inputFileName.substring(0, inputFileName.lastIndexOf(".")); String inputFileNamePrefix = inputFileName.substring(0, inputFileName.lastIndexOf("."));
String strLocalTif = fileDir + inputFileName; String strLocalTif = fileDir + inputFileName;
File fileTiff = new File(strLocalTif); File fileTiff = new File(strLocalTif);
// 如果本地不存在这个tif文件则下载 // 如果本地不存在这个tif文件则下载
if(!fileTiff.exists()){ if (!fileTiff.exists()) {
ReturnResponse<String> response = DownloadUtils.downLoad(fileAttribute, inputFileName); ReturnResponse<String> response = DownloadUtils.downLoad(fileAttribute, inputFileName);
if (response.isFailure()) { if (response.isFailure()) {
return NOT_SUPPORTED_FILE_PAGE; return NOT_SUPPORTED_FILE_PAGE;
@ -69,22 +74,23 @@ public class TiffFilePreviewImpl implements FilePreview {
} }
String baseUrl = BaseUrlFilter.getBaseUrl(); String baseUrl = BaseUrlFilter.getBaseUrl();
if("pdf".equalsIgnoreCase(tifPreviewType)){ if ("pdf".equalsIgnoreCase(tifPreviewType)) {
// 以PDF模式预览的过程 // 以PDF模式预览的过程
File filePdf = new File(fileDir + inputFileNamePrefix + ".pdf"); File filePdf = new File(fileDir + inputFileNamePrefix + ".pdf");
// 如果本地不存在对应的pdf则调用转换过程。否则直接用现有的pdf文件 // 如果本地不存在对应的pdf则调用转换过程。否则直接用现有的pdf文件
if(!filePdf.exists()){ if (!filePdf.exists()) {
filePdf = ConvertPicUtil.convertTif2Pdf(strLocalTif, fileDir + inputFileNamePrefix + ".pdf"); filePdf = ConvertPicUtil.convertTif2Pdf(strLocalTif, fileDir + inputFileNamePrefix + ".pdf");
} }
// 如果pdf已经存在则将url路径加入到对象中返回给页面 // 如果pdf已经存在则将url路径加入到对象中返回给页面
if(filePdf.exists()){ assert filePdf != null;
if (filePdf.exists()) {
String pdfUrl = baseUrl + inputFileNamePrefix + ".pdf"; String pdfUrl = baseUrl + inputFileNamePrefix + ".pdf";
model.addAttribute("pdfUrl", pdfUrl); model.addAttribute("pdfUrl", pdfUrl);
return PDF_FILE_PREVIEW_PAGE; return PDF_FILE_PREVIEW_PAGE;
} }
}else{ } else {
// 以JPG模式预览的过程 // 以JPG模式预览的过程
String strJpgFilePathName = fileDir + inputFileNamePrefix + ".jpg"; String strJpgFilePathName = fileDir + inputFileNamePrefix + ".jpg";
// 将tif转换为jpg返回转换后的文件路径、文件名的list // 将tif转换为jpg返回转换后的文件路径、文件名的list
@ -92,7 +98,7 @@ public class TiffFilePreviewImpl implements FilePreview {
// 将返回页面的图片url的list对象 // 将返回页面的图片url的list对象
List<String> listImageUrls = new ArrayList<>(); List<String> listImageUrls = new ArrayList<>();
// 循环拼装url的list对象 // 循环拼装url的list对象
for(String strJpg : listPic2Jpg){ for (String strJpg : listPic2Jpg) {
listImageUrls.add(baseUrl + strJpg); listImageUrls.add(baseUrl + strJpg);
} }
@ -101,8 +107,8 @@ public class TiffFilePreviewImpl implements FilePreview {
} }
// 转换后的tif没用了可以删掉了 // 转换后的tif没用了可以删掉了
if(fileTiff.exists()){ if (fileTiff.exists() && !fileTiff.delete()) {
fileTiff.delete(); logger.error("{} 清理失败", strLocalTif);
} }
return PICTURE_FILE_PREVIEW_PAGE; return PICTURE_FILE_PREVIEW_PAGE;

View File

@ -27,6 +27,7 @@ public class ConvertPicUtil {
/** /**
* Tif JPG * Tif JPG
*
* @param strInputFile * @param strInputFile
* @param strOutputFile * @param strOutputFile
* @return boolean * @return boolean
@ -60,8 +61,8 @@ public class ConvertPicUtil {
int intTifCount = imageDecoder.getNumPages(); int intTifCount = imageDecoder.getNumPages();
logger.info("该tif文件共有【" + intTifCount + "】页"); logger.info("该tif文件共有【" + intTifCount + "】页");
String strJpgPath = ""; String strJpgPath;
String strJpgUrl = ""; String strJpgUrl;
if (intTifCount == 1) { if (intTifCount == 1) {
// 如果是单页tif文件则转换的目标文件夹就在指定的位置 // 如果是单页tif文件则转换的目标文件夹就在指定的位置
strJpgPath = strOutputFile.substring(0, strOutputFile.lastIndexOf("/")); strJpgPath = strOutputFile.substring(0, strOutputFile.lastIndexOf("/"));
@ -72,17 +73,17 @@ public class ConvertPicUtil {
// 处理目标文件夹,如果不存在则自动创建 // 处理目标文件夹,如果不存在则自动创建
File fileJpgPath = new File(strJpgPath); File fileJpgPath = new File(strJpgPath);
if (!fileJpgPath.exists()) { if (!fileJpgPath.exists() && !fileJpgPath.mkdirs()) {
fileJpgPath.mkdirs(); logger.error("{} 创建失败", strJpgPath);
} }
// 循环处理每页tif文件转换为jpg // 循环处理每页tif文件转换为jpg
for (int i = 0; i < intTifCount; i++) { for (int i = 0; i < intTifCount; i++) {
String strJpg = ""; String strJpg;
if(intTifCount == 1){ if (intTifCount == 1) {
strJpg = strJpgPath + "/" + strFilePrefix + ".jpg"; strJpg = strJpgPath + "/" + strFilePrefix + ".jpg";
strJpgUrl = strFilePrefix + ".jpg"; strJpgUrl = strFilePrefix + ".jpg";
}else{ } else {
strJpg = strJpgPath + "/" + i + ".jpg"; strJpg = strJpgPath + "/" + i + ".jpg";
strJpgUrl = strFilePrefix + "/" + i + ".jpg"; strJpgUrl = strFilePrefix + "/" + i + ".jpg";
} }
@ -90,7 +91,7 @@ public class ConvertPicUtil {
File fileJpg = new File(strJpg); File fileJpg = new File(strJpg);
// 如果文件不存在,则生成 // 如果文件不存在,则生成
if(!fileJpg.exists()){ if (!fileJpg.exists()) {
RenderedImage renderedImage = imageDecoder.decodeAsRenderedImage(i); RenderedImage renderedImage = imageDecoder.decodeAsRenderedImage(i);
ParameterBlock pb = new ParameterBlock(); ParameterBlock pb = new ParameterBlock();
pb.addSource(renderedImage); pb.addSource(renderedImage);
@ -102,7 +103,7 @@ public class ConvertPicUtil {
renderedOp.dispose(); renderedOp.dispose();
logger.info("每页分别保存至: " + fileJpg.getCanonicalPath()); logger.info("每页分别保存至: " + fileJpg.getCanonicalPath());
}else{ } else {
logger.info("JPG文件已存在 " + fileJpg.getCanonicalPath()); logger.info("JPG文件已存在 " + fileJpg.getCanonicalPath());
} }
@ -118,21 +119,19 @@ public class ConvertPicUtil {
try { try {
fileSeekStream.close(); fileSeekStream.close();
} catch (IOException e) { } catch (IOException e) {
logger.error(e.getMessage(), e);
} }
fileSeekStream = null;
} }
} }
} }
/** /**
* JpgPdf * JpgPdf
* *
* @param strJpgFile jpg * @param strJpgFile jpg
* @param strPdfFile pdf * @param strPdfFile pdf
* @return
*/ */
public static File convertJpg2Pdf(String strJpgFile, String strPdfFile) { public static void convertJpg2Pdf(String strJpgFile, String strPdfFile) {
Document document = new Document(); Document document = new Document();
// 设置文档页边距 // 设置文档页边距
document.setMargins(0, 0, 0, 0); document.setMargins(0, 0, 0, 0);
@ -157,23 +156,18 @@ public class ConvertPicUtil {
document.add(image); document.add(image);
} catch (Exception ioe) { } catch (Exception ioe) {
ioe.printStackTrace(); ioe.printStackTrace();
return null;
} finally { } finally {
//关闭文档 //关闭文档
document.close(); document.close();
try { try {
assert fos != null;
fos.flush(); fos.flush();
fos.close(); fos.close();
File filePDF = new File(strPdfFile);
return filePDF;
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
} }
} }
return null;
} }
@ -182,7 +176,7 @@ public class ConvertPicUtil {
* *
* @param strTifFile tif * @param strTifFile tif
* @param strPdfFile pdf * @param strPdfFile pdf
* @return * @return File
*/ */
public static File convertTif2Pdf(String strTifFile, String strPdfFile) { public static File convertTif2Pdf(String strTifFile, String strPdfFile) {
try { try {
@ -198,16 +192,16 @@ public class ConvertPicUtil {
Image image; Image image;
File filePDF; File filePDF;
if(intPages == 1){ if (intPages == 1) {
String strJpg = strTifFile.substring(0, strTifFile.lastIndexOf(".")) + ".jpg"; String strJpg = strTifFile.substring(0, strTifFile.lastIndexOf(".")) + ".jpg";
File fileJpg = new File(strJpg); File fileJpg = new File(strJpg);
List<String> listPic2Jpg = convertTif2Jpg(strTifFile, strJpg); List<String> listPic2Jpg = convertTif2Jpg(strTifFile, strJpg);
if(listPic2Jpg != null && fileJpg.exists()){ if (listPic2Jpg != null && fileJpg.exists()) {
filePDF = convertJpg2Pdf(strJpg, strPdfFile); convertJpg2Pdf(strJpg, strPdfFile);
} }
}else{ } else {
for (int i = 1; i <= intPages; i++) { for (int i = 1; i <= intPages; i++) {
image = TiffImage.getTiffImage(rafa, i); image = TiffImage.getTiffImage(rafa, i);
// 设置页面宽高与图片一致 // 设置页面宽高与图片一致
@ -229,7 +223,7 @@ public class ConvertPicUtil {
return filePDF; return filePDF;
} catch (Exception e) { } catch (Exception e) {
System.out.println(e.toString()); logger.error(e.getMessage(), e);
} }
return null; return null;
} }

View File

@ -1,26 +1,33 @@
package cn.keking.web.controller; package cn.keking.web.controller;
import cn.keking.config.ConfigConstants; import cn.keking.config.ConfigConstants;
import cn.keking.model.ReturnResponse;
import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import cn.keking.model.ReturnResponse;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.util.StreamUtils; import org.springframework.util.StreamUtils;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.*;
import org.springframework.web.util.HtmlUtils; import org.springframework.web.util.HtmlUtils;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
/** /**
*
* @author yudian-it * @author yudian-it
* @date 2017/12/1 * @date 2017/12/1
*/ */
@ -33,7 +40,7 @@ public class FileController {
private final String demoDir = "demo"; private final String demoDir = "demo";
private final String demoPath = demoDir + File.separator; private final String demoPath = demoDir + File.separator;
@RequestMapping(value = "fileUpload", method = RequestMethod.POST) @PostMapping("/fileUpload")
public String fileUpload(@RequestParam("file") MultipartFile file) throws JsonProcessingException { public String fileUpload(@RequestParam("file") MultipartFile file) throws JsonProcessingException {
if (ConfigConstants.getFileUploadDisable()) { if (ConfigConstants.getFileUploadDisable()) {
return new ObjectMapper().writeValueAsString(ReturnResponse.failure("文件传接口已禁用")); return new ObjectMapper().writeValueAsString(ReturnResponse.failure("文件传接口已禁用"));
@ -41,8 +48,9 @@ public class FileController {
// 获取文件名 // 获取文件名
String fileName = file.getOriginalFilename(); String fileName = file.getOriginalFilename();
//判断是否为IE浏览器的文件名IE浏览器下文件名会带有盘符信息 //判断是否为IE浏览器的文件名IE浏览器下文件名会带有盘符信息
// escaping dangerous characters to prevent XSS // escaping dangerous characters to prevent XSS
assert fileName != null;
fileName = HtmlUtils.htmlEscape(fileName, StandardCharsets.UTF_8.name()); fileName = HtmlUtils.htmlEscape(fileName, StandardCharsets.UTF_8.name());
// Check for Unix-style path // Check for Unix-style path
@ -51,7 +59,7 @@ public class FileController {
int winSep = fileName.lastIndexOf('\\'); int winSep = fileName.lastIndexOf('\\');
// Cut off at latest possible point // Cut off at latest possible point
int pos = (Math.max(winSep, unixSep)); int pos = (Math.max(winSep, unixSep));
if (pos != -1) { if (pos != -1) {
fileName = fileName.substring(pos + 1); fileName = fileName.substring(pos + 1);
} }
// 判断是否存在同名文件 // 判断是否存在同名文件
@ -60,10 +68,10 @@ public class FileController {
} }
File outFile = new File(fileDir + demoPath); File outFile = new File(fileDir + demoPath);
if (!outFile.exists() && !outFile.mkdirs()) { if (!outFile.exists() && !outFile.mkdirs()) {
logger.error("创建文件夹【{}】失败,请检查目录权限!",fileDir + demoPath); logger.error("创建文件夹【{}】失败,请检查目录权限!", fileDir + demoPath);
} }
logger.info("上传文件:{}", fileDir + demoPath + fileName); logger.info("上传文件:{}", fileDir + demoPath + fileName);
try(InputStream in = file.getInputStream(); OutputStream out = new FileOutputStream(fileDir + demoPath + fileName)) { try (InputStream in = file.getInputStream(); OutputStream out = new FileOutputStream(fileDir + demoPath + fileName)) {
StreamUtils.copy(in, out); StreamUtils.copy(in, out);
return new ObjectMapper().writeValueAsString(ReturnResponse.success(null)); return new ObjectMapper().writeValueAsString(ReturnResponse.success(null));
} catch (IOException e) { } catch (IOException e) {
@ -72,7 +80,7 @@ public class FileController {
} }
} }
@RequestMapping(value = "deleteFile", method = RequestMethod.GET) @GetMapping("/deleteFile")
public String deleteFile(String fileName) throws JsonProcessingException { public String deleteFile(String fileName) throws JsonProcessingException {
if (fileName.contains("/")) { if (fileName.contains("/")) {
fileName = fileName.substring(fileName.lastIndexOf("/") + 1); fileName = fileName.substring(fileName.lastIndexOf("/") + 1);
@ -80,12 +88,12 @@ public class FileController {
File file = new File(fileDir + demoPath + fileName); File file = new File(fileDir + demoPath + fileName);
logger.info("删除文件:{}", file.getAbsolutePath()); logger.info("删除文件:{}", file.getAbsolutePath());
if (file.exists() && !file.delete()) { if (file.exists() && !file.delete()) {
logger.error("删除文件【{}】失败,请检查目录权限!",file.getPath()); logger.error("删除文件【{}】失败,请检查目录权限!", file.getPath());
} }
return new ObjectMapper().writeValueAsString(ReturnResponse.success()); return new ObjectMapper().writeValueAsString(ReturnResponse.success());
} }
@RequestMapping(value = "listFiles", method = RequestMethod.GET) @GetMapping("/listFiles")
public String getFiles() throws JsonProcessingException { public String getFiles() throws JsonProcessingException {
List<Map<String, String>> list = new ArrayList<>(); List<Map<String, String>> list = new ArrayList<>();
File file = new File(fileDir + demoPath); File file = new File(fileDir + demoPath);

View File

@ -1,8 +1,7 @@
package cn.keking.web.controller; package cn.keking.web.controller;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMethod;
/** /**
* *
@ -12,12 +11,12 @@ import org.springframework.web.bind.annotation.RequestMethod;
@Controller @Controller
public class IndexController { public class IndexController {
@RequestMapping(value = "/index", method = RequestMethod.GET) @GetMapping( "/index")
public String go2Index(){ public String go2Index(){
return "index"; return "index";
} }
@RequestMapping(value = "/", method = RequestMethod.GET) @GetMapping( "/")
public String root() { public String root() {
return "redirect:/index"; return "redirect:/index";
} }

View File

@ -16,8 +16,7 @@ import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
import org.springframework.ui.Model; import org.springframework.ui.Model;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.util.HtmlUtils; import org.springframework.web.util.HtmlUtils;
@ -53,7 +52,7 @@ public class OnlinePreviewController {
this.otherFilePreview = otherFilePreview; this.otherFilePreview = otherFilePreview;
} }
@RequestMapping(value = "/onlinePreview") @GetMapping( "/onlinePreview")
public String onlinePreview(String url, Model model, HttpServletRequest req) { public String onlinePreview(String url, Model model, HttpServletRequest req) {
String fileUrl; String fileUrl;
try { try {
@ -69,7 +68,7 @@ public class OnlinePreviewController {
return filePreview.filePreviewHandle(fileUrl, model, fileAttribute); return filePreview.filePreviewHandle(fileUrl, model, fileAttribute);
} }
@RequestMapping(value = "/picturesPreview") @GetMapping( "/picturesPreview")
public String picturesPreview(String urls, Model model, HttpServletRequest req) throws UnsupportedEncodingException { public String picturesPreview(String urls, Model model, HttpServletRequest req) throws UnsupportedEncodingException {
String fileUrls; String fileUrls;
try { try {
@ -104,15 +103,16 @@ public class OnlinePreviewController {
* @param urlPath url * @param urlPath url
* @param response response * @param response response
*/ */
@RequestMapping(value = "/getCorsFile", method = RequestMethod.GET) @GetMapping("/getCorsFile")
public void getCorsFile(String urlPath, HttpServletResponse response) { public void getCorsFile(String urlPath, HttpServletResponse response) {
try { try {
urlPath = new String(Base64.decodeBase64(urlPath), StandardCharsets.UTF_8); urlPath = new String(Base64.decodeBase64(urlPath), StandardCharsets.UTF_8);
} catch (Exception ex) { } catch (Exception ex) {
logger.error(String.format(BASE64_DECODE_ERROR_MSG, urlPath, ex)); logger.error(String.format(BASE64_DECODE_ERROR_MSG, urlPath),ex);
return; return;
} }
if (urlPath == null || urlPath.toLowerCase().startsWith("file:") || urlPath.toLowerCase().startsWith("file%3") || !urlPath.toLowerCase().startsWith("http")) { if (urlPath.toLowerCase().startsWith("file:") || urlPath.toLowerCase().startsWith("file%3")
|| !urlPath.toLowerCase().startsWith("http")) {
logger.info("读取跨域文件异常可能存在非法访问urlPath{}", urlPath); logger.info("读取跨域文件异常可能存在非法访问urlPath{}", urlPath);
return; return;
} }
@ -132,7 +132,7 @@ public class OnlinePreviewController {
* *
* @param url * @param url
*/ */
@RequestMapping("/addTask") @GetMapping("/addTask")
@ResponseBody @ResponseBody
public String addQueueTask(String url) { public String addQueueTask(String url) {
logger.info("添加转码队列url{}", url); logger.info("添加转码队列url{}", url);

View File

@ -2,16 +2,16 @@ package cn.keking.web.filter;
import cn.keking.config.ConfigConstants; import cn.keking.config.ConfigConstants;
import cn.keking.utils.WebUtils; import cn.keking.utils.WebUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.core.io.ClassPathResource;
import org.springframework.util.Base64Utils;
import org.springframework.util.FileCopyUtils;
import javax.servlet.*;
import java.io.IOException; import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import org.springframework.core.io.ClassPathResource;
import org.springframework.util.FileCopyUtils;
/** /**
* @author chenjh * @author chenjh