解决springcloud阿里云OSS文件访问跨域问题的实现

网友投稿 1046 2022-10-01

解决springcloud阿里云OSS文件访问跨域问题的实现

解决springcloud阿里云OSS文件访问跨域问题的实现

目录引言解决

引言

最近在高德地图中引用阿里云OSS存储的图片时,出现跨域访问问题,特此记录,以方便后续同学参考

解决

1、在阿里云OSS后台管理中,进入权限管理,进入跨域设置,添加跨域规则,设置来源为*

2、至此配置完成后访问图片还是会出现跨域问题,这是因为OSS文件默认会开启缓存,及后续访问的实际上是缓存的文件,这就会导致不能匹配到我们上述配置的跨域规则

于是我们需要将缓存禁用掉,如果文件就一两个的话,可以直接在后台中设置禁用缓存,将HTTP头中Cache-Control设置为no-cache

3、因为目前阿里云后台只支持单个文件的HTTP头设置,并不支持批量设置,所以到有多个文件或者后续上传的文件都不需要缓存时就不能满足了

那么我们如何来实现这个批量禁用缓存的需求呢。答案就是在上传文件到OSS的时候在请求头中设置Cache-Control为no-cache

首先上传阿里云OSS的接口是基于aliyun-sdk-oss依赖的

com.aliyun.oss

aliyun-sdk-oss

其次我们观察该依赖包提供的上传文件接口,会发现其中有一个方法可以设置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的响应头http://了。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序转换器之 loader设计实现(微信小程序码转换)
下一篇:HDOJ 4763 - Theme Section 利用KMP的fail数组,,很暴力
相关文章

 发表评论

暂时没有评论,来抢沙发吧~