2023年8月4日更新:本人正在更新谷粒商城的依赖,更新完会发布。
我的依赖版本:SpringBoot:3.0.6
SpringCloud:2022.0.0
JDK17
参考Oss最新服务端签名直传官方文档:Java - 对象存储 OSS - 阿里云
由于阿里巴巴官方对OSS依赖方式的更新,导致视频中的依赖已不可用,采用阿里巴巴最新文档,换用新的依赖。
Springcloud alibaba与 Spring Boot、Spring Cloud兼容性参考这个文档:选择你需要的版本版本说明 · alibaba/spring-cloud-alibaba Wiki · GitHub
记得启动你的product、thirdparty、gateway、renrenfast前端后端应用
我的代码如下:
gulimall-thirdparty:pom.xml添加下列依赖:
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>2022.0.0</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2022.0.0.0-RC2</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
gulimall-thirdparty添加下列依赖,指定aliyun-sdk-oss为3.17.1版本:
<dependency>
<groupId>com.aliyun.oss</groupId>
<artifactId>aliyun-sdk-oss</artifactId>
<version>3.17.1</version>
</dependency>
application.yml配置,请自行填入你的OSS配置
Host地址,格式为https://bucketname.endpoint。
oss:
access-key:
secret-key:
endpoint:
bucket:
host:
这是我服务端获取签名的代码:
package com.shihao.thirdparty.controller;
import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import com.aliyun.oss.common.utils.BinaryUtil;
import com.aliyun.oss.model.MatchMode;
import com.aliyun.oss.model.PolicyConditions;
import com.shihao.common.utils.R;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.LinkedHashMap;
import java.util.Map;
/**
* Oss 获取服务端签名
* @return
*/
@WebServlet(asyncSupported = true)
@RestController
@RequestMapping("thirdparty")
public class CallbackServer extends HttpServlet {
@Value("${oss.endpoint}")
private String endpoint;
@Value("${oss.access-key}")
private String accessId;
@Value("${oss.secret-key}")
private String accessKey;
@Value("${oss.host}")
private String host;
/**
* Get请求
*/
@RequestMapping("/oss/policy")
protected R GetPolicy() {
// 设置上传到OSS文件的前缀,可置空此项。置空后,文件将上传至Bucket的根目录下。
SimpleDateFormat simpleDateFormat = new SimpleDateFormat();
//year
simpleDateFormat.applyPattern("yyyy");
String year = simpleDateFormat.format(new Date());
//date
simpleDateFormat.applyPattern("MM/dd");
String date =simpleDateFormat.format(new Date());
//directory
String dir = year+"/"+date;
// 创建ossClient实例。
OSS ossClient = new OSSClientBuilder().build(endpoint, accessId, accessKey);
Map<String, String> respMap = new LinkedHashMap<String, String>();
try {
long expireTime = 30;
long expireEndTime = System.currentTimeMillis() + expireTime * 1000;
Date expiration = new Date(expireEndTime);
PolicyConditions policyConds = new PolicyConditions();
policyConds.addConditionItem(PolicyConditions.COND_CONTENT_LENGTH_RANGE, 0, 1048576000);
policyConds.addConditionItem(MatchMode.StartWith, PolicyConditions.COND_KEY, dir);
String postPolicy = ossClient.generatePostPolicy(expiration, policyConds);
byte[] binaryData = postPolicy.getBytes("utf-8");
String encodedPolicy = BinaryUtil.toBase64String(binaryData);
String postSignature = ossClient.calculatePostSignature(postPolicy);
respMap.put("accessid", accessId);
respMap.put("policy", encodedPolicy);
respMap.put("signature", postSignature);
respMap.put("dir", dir);
respMap.put("host", host);
respMap.put("expire", String.valueOf(expireEndTime / 1000));
// respMap.put("expire", formatISO8601Date(expiration));
} catch (Exception e) {
// Assert.fail(e.getMessage());
System.out.println(e.getMessage());
}
return R.ok().put("data",respMap);
}
}
测试成功!
![](https://img-blog.csdnimg.cn/c3061a0d76ba4e1fb70d6744c7124953.png)
Done!