引言
最近在高德地图中引用阿里云OSS存储的图片时,出现跨域访问问题,特此记录,以方便后续同学参考
解决
1、在阿里云OSS后台管理中,进入权限管理,进入跨域设置,添加跨域规则,设置来源为*
2、至此配置完成后访问图片还是会出现跨域问题,这是因为OSS文件默认会开启缓存,及后续访问的实际上是缓存的文件,这就会导致不能匹配到我们上述配置的跨域规则
于是我们需要将缓存禁用掉,如果文件就一两个的话,可以直接在后台中设置禁用缓存,将HTTP头中Cache-Control
设置为no-cache
3、因为目前阿里云后台只支持单个文件的HTTP头设置,并不支持批量设置,所以到有多个文件或者后续上传的文件都不需要缓存时就不能满足了
那么我们如何来实现这个批量禁用缓存的需求呢。答案就是在上传文件到OSS的时候在请求头中设置Cache-Control
为no-cache
首先上传阿里云OSS的接口是基于aliyun-sdk-oss
依赖的
<dependency>
<groupId>com.aliyun.oss</groupId>
<artifactId>aliyun-sdk-oss</artifactId>
</dependency>
其次我们观察该依赖包提供的上传文件接口,会发现其中有一个方法可以设置ObjectMetadata
而ObjectMetadata
中是可以设置Header的
那么解决的方法就很清晰了,我们只需要在调用该文件上传put
方法时,在ObjectMetadata中设置上我们需要的Header即可,参考代码如下:
private final OSSClient ossClient;
@PostMapping("/put-file-with-nocache")
public PutObjectResult putFileWithNoCache(@RequestParam MultipartFile file) {
String fileName = file.getOriginalFilename();
ObjectMetadata metadata = new ObjectMetadata();
// 取消文件缓存,文件每次都会从OSS服务器获取
metadata.setHeader("Cache-Control", "no-cache");
metadata.setHeader("Expires", "0");
PutObjectResult bucketName = ossClient.putObject("bucketName", fileName, file.getInputStream(), metadata);
return bucketName;
}
之后通过该接口上传的图片就不会再有跨域问题了,我们在测试工具中调用访问该图片,也会发现其response中会多出一个cache-control: no-cache
的响应头了。
到此这篇关于解决springcloud阿里云OSS文件访问跨域问题的实现的文章就介绍到这了,更多相关springcloud OSS文件跨域内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:解决springcloud阿里云OSS文件访问跨域问题的实现
基础教程推荐
- ConditionalOnProperty配置swagger不生效问题及解决 2023-01-02
- java基础知识之FileInputStream流的使用 2023-08-11
- Java并发编程进阶之线程控制篇 2023-03-07
- java实现多人聊天系统 2023-05-19
- springboot自定义starter方法及注解实例 2023-03-31
- Java数据结构之对象比较详解 2023-03-07
- Java实现查找文件和替换文件内容 2023-04-06
- JDK数组阻塞队列源码深入分析总结 2023-04-18
- Java实现线程插队的示例代码 2022-09-03
- Java文件管理操作的知识点整理 2023-05-19