upload文件上传(跳过zuul的缓存)

首先编写controller层

@RestController
@RequestMapping("upload")
public class UploadController {

    @Autowired
    private UploadService uploadService;

    /**
     * 文件上传
     * @param file
     * @return
     */
    @PostMapping("image")
    public ResponseEntity<String> uploadImage(@RequestParam("file")MultipartFile file){
        System.out.println("=====================================文件上传"+file.getOriginalFilename());
        return ResponseEntity.ok(uploadService.uploadImage(file));
    }
}

service层,在service层对文件进行处理

@Service
@Slf4j
public class UploadService {

    private static final List<String> ALLOW_TYPES = Arrays.asList("image/jpeg","image/png","image/gif");

    public String uploadImage(MultipartFile file) {
        try {
         //文件类型校验
            String type = file.getContentType();
            if (!ALLOW_TYPES.contains(type)){
                throw new LyException(ExceptionEnum.IMAGE_FILE_TYPE);
            }
            //文件内容校验
            BufferedImage image = ImageIO.read(file.getInputStream());
            if (image == null){
                throw new LyException(ExceptionEnum.IMAGE_FILE_TYPE);
            }
            //保存文件到本地
        File dist = new File("F:\\BaiduNetdiskDownload\\upload",file.getOriginalFilename());
            file.transferTo(dist);
            return "Http://image.leyou.com/" + file.getOriginalFilename();
        } catch (IOException e) {
            log.error("上传文件失败",e);
            throw new LyException(ExceptionEnum.BRAND_NOT_FOUND);
        }
        //返回路劲
    }
}

最后返回的是文件的路劲

在Nginx的配置文件中添加,可以跳过zuul的缓存,但还是会通过zuul网关

# 上传路径的映射
		location /api/upload {	
			rewrite "^/(.*)$" /zuul/$1;  #匹配/后面的一切
        }

Nginx的优先级规范:

路劲越准确的优先级越高,并不是看谁在前
/ 的优先级是最低的

  • 增值表达式:

  • () 是分组

  • . 任意

  • *数量

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值