feat: 添加文件上传接口
This commit is contained in:
@@ -7,6 +7,7 @@ import cn.celess.blog.exception.MyException;
|
|||||||
import cn.celess.blog.service.CountService;
|
import cn.celess.blog.service.CountService;
|
||||||
import cn.celess.blog.service.QiniuService;
|
import cn.celess.blog.service.QiniuService;
|
||||||
import cn.celess.blog.util.HttpUtil;
|
import cn.celess.blog.util.HttpUtil;
|
||||||
|
import cn.celess.blog.util.RedisUserUtil;
|
||||||
import cn.celess.blog.util.RedisUtil;
|
import cn.celess.blog.util.RedisUtil;
|
||||||
import cn.celess.blog.util.VeriCodeUtil;
|
import cn.celess.blog.util.VeriCodeUtil;
|
||||||
import com.fasterxml.jackson.databind.JsonNode;
|
import com.fasterxml.jackson.databind.JsonNode;
|
||||||
@@ -27,9 +28,7 @@ import javax.servlet.http.HttpServletResponse;
|
|||||||
import java.awt.image.BufferedImage;
|
import java.awt.image.BufferedImage;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.util.Enumeration;
|
import java.util.*;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -47,7 +46,7 @@ public class CommonController {
|
|||||||
@Autowired
|
@Autowired
|
||||||
RedisUtil redisUtil;
|
RedisUtil redisUtil;
|
||||||
@Autowired
|
@Autowired
|
||||||
HttpServletRequest request;
|
RedisUserUtil redisUserUtil;
|
||||||
|
|
||||||
|
|
||||||
@GetMapping("/counts")
|
@GetMapping("/counts")
|
||||||
@@ -89,7 +88,7 @@ public class CommonController {
|
|||||||
* @throws IOException IOException
|
* @throws IOException IOException
|
||||||
*/
|
*/
|
||||||
@GetMapping(value = "/imgCode", produces = MediaType.IMAGE_PNG_VALUE)
|
@GetMapping(value = "/imgCode", produces = MediaType.IMAGE_PNG_VALUE)
|
||||||
public void getImg(HttpServletResponse response) throws IOException {
|
public void getImg(HttpServletRequest request, HttpServletResponse response) throws IOException {
|
||||||
Object[] obj = VeriCodeUtil.createImage();
|
Object[] obj = VeriCodeUtil.createImage();
|
||||||
request.getSession().setAttribute("code", obj[0]);
|
request.getSession().setAttribute("code", obj[0]);
|
||||||
//将图片输出给浏览器
|
//将图片输出给浏览器
|
||||||
@@ -133,9 +132,10 @@ public class CommonController {
|
|||||||
* FIXME :: 单张图片多次上传的问题
|
* FIXME :: 单张图片多次上传的问题
|
||||||
* editor.md图片上传的接口
|
* editor.md图片上传的接口
|
||||||
* FUCK !!!
|
* FUCK !!!
|
||||||
*
|
* !! 推荐使用 fileUpload(/fileUpload) 接口
|
||||||
* @param file 文件
|
* @param file 文件
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
@PostMapping("/imgUpload")
|
@PostMapping("/imgUpload")
|
||||||
public void upload(HttpServletRequest request, HttpServletResponse response, @RequestParam("editormd-image-file") MultipartFile file) throws IOException {
|
public void upload(HttpServletRequest request, HttpServletResponse response, @RequestParam("editormd-image-file") MultipartFile file) throws IOException {
|
||||||
Map<String, Object> map = new HashMap<>();
|
Map<String, Object> map = new HashMap<>();
|
||||||
@@ -186,4 +186,37 @@ public class CommonController {
|
|||||||
JsonNode images = root.get("images").elements().next();
|
JsonNode images = root.get("images").elements().next();
|
||||||
return Response.success("https://cn.bing.com" + images.get("url").asText());
|
return Response.success("https://cn.bing.com" + images.get("url").asText());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/fileUpload")
|
||||||
|
public Response<List<Map<String, Object>>> fileUpload(@RequestParam("file[]") MultipartFile[] files) throws IOException {
|
||||||
|
List<Map<String, Object>> result = new ArrayList<>();
|
||||||
|
String uploadTimesStr = redisUtil.get(redisUserUtil.get().getEmail() + "-fileUploadTimes");
|
||||||
|
int uploadTimes = 0;
|
||||||
|
if (uploadTimesStr != null) {
|
||||||
|
uploadTimes = Integer.parseInt(uploadTimesStr);
|
||||||
|
}
|
||||||
|
if (uploadTimes == 10) {
|
||||||
|
throw new MyException(ResponseEnum.FAILURE.getCode(), "上传次数已达10次,请2小时后在上传");
|
||||||
|
}
|
||||||
|
if (files.length == 0) {
|
||||||
|
throw new MyException(ResponseEnum.NO_FILE);
|
||||||
|
}
|
||||||
|
for (MultipartFile file : files) {
|
||||||
|
Map<String, Object> resp = new HashMap<>(4);
|
||||||
|
|
||||||
|
String fileName = file.getOriginalFilename();
|
||||||
|
assert fileName != null;
|
||||||
|
String mime = fileName.substring(fileName.lastIndexOf("."));
|
||||||
|
String name = fileName.replace(mime, "").replaceAll(" ", "");
|
||||||
|
QiniuResponse qiniuResponse = qiniuService.uploadFile(file.getInputStream(), "file_" + name + '_' + System.currentTimeMillis() + mime);
|
||||||
|
resp.put("originalFilename", fileName);
|
||||||
|
resp.put("success", qiniuResponse != null);
|
||||||
|
if (qiniuResponse != null) {
|
||||||
|
resp.put("host", "http://cdn.celess.cn/");
|
||||||
|
resp.put("path", qiniuResponse.key);
|
||||||
|
}
|
||||||
|
result.add(resp);
|
||||||
|
}
|
||||||
|
return Response.success(result);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -62,6 +62,8 @@ public enum ResponseEnum {
|
|||||||
APPLY_LINK_NO_ADD_THIS_SITE(7200, "暂未在您的网站中抓取到本站链接"),
|
APPLY_LINK_NO_ADD_THIS_SITE(7200, "暂未在您的网站中抓取到本站链接"),
|
||||||
DATA_EXPIRED(7300, "数据过期"),
|
DATA_EXPIRED(7300, "数据过期"),
|
||||||
CANNOT_GET_DATA(7400, "暂无法获取到数据"),
|
CANNOT_GET_DATA(7400, "暂无法获取到数据"),
|
||||||
|
NO_FILE(7500, "未选择文件,请重新选择"),
|
||||||
|
|
||||||
|
|
||||||
//提交更新之前,没有获取数据/,
|
//提交更新之前,没有获取数据/,
|
||||||
DID_NOT_GET_THE_DATA(8020, "非法访问"),
|
DID_NOT_GET_THE_DATA(8020, "非法访问"),
|
||||||
|
|||||||
@@ -32,8 +32,8 @@ public class Response<T> implements Serializable {
|
|||||||
* @param result 结果
|
* @param result 结果
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public static Response success(Object result) {
|
public static <T> Response<T> success(T result) {
|
||||||
return new Response(ResponseEnum.SUCCESS.getCode(), ResponseEnum.SUCCESS.getMsg(), result);
|
return new Response<T>(ResponseEnum.SUCCESS.getCode(), ResponseEnum.SUCCESS.getMsg(), result);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -42,8 +42,8 @@ public class Response<T> implements Serializable {
|
|||||||
* @param result 结果
|
* @param result 结果
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public static Response failure(String result) {
|
public static Response<String> failure(String result) {
|
||||||
return new Response(ResponseEnum.FAILURE.getCode(), ResponseEnum.FAILURE.getMsg(), result);
|
return new Response<String>(ResponseEnum.FAILURE.getCode(), ResponseEnum.FAILURE.getMsg(), result);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -53,8 +53,8 @@ public class Response<T> implements Serializable {
|
|||||||
* @param result 结果
|
* @param result 结果
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public static Response response(ResponseEnum r, String result) {
|
public static <T> Response<T> response(ResponseEnum r, T result) {
|
||||||
return new Response(r.getCode(), r.getMsg(), result);
|
return new Response<T>(r.getCode(), r.getMsg(), result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SneakyThrows
|
@SneakyThrows
|
||||||
|
|||||||
Reference in New Issue
Block a user