​endpoint​​和​​bucket​来源于下面,地址则是创建完bucket后点开这个bucket就会看到

​accessID​​和​​accessKey​​则是拥有这个bucket管理的用户,后面内容可以找到这个信息

使用ElementUi中的el-upload组件,后台服务器签名,前端直传阿里云OSS。_上传

需要有前面的操作:​​开启OSS对象存储服务,创建Bucket以及添加一些必要的设置​

后台服务器签名:​​阿里云OSS文档地址​

首先需要有一个能获取签名的地址

第一步、搭建签名服务器

​方式一、有外网服务器的情况​

下载java端的sdk

​OSS签名程序的sdk下载地址​

下载完后,修改源码中的

使用ElementUi中的el-upload组件,后台服务器签名,前端直传阿里云OSS。_ios_02

如果有修改端口的需求,修改App中的port

使用ElementUi中的el-upload组件,后台服务器签名,前端直传阿里云OSS。_服务器_03

将项目打成​​jar​​包

找到下面这个jar包

使用ElementUi中的el-upload组件,后台服务器签名,前端直传阿里云OSS。_ios_04

通过​​java -jar appservermaven-1.0.0.jar​​将其部署到自己的服务器上

​方式二、集成到自己的springboot项目中​

​OSS的文档地址​

​第一步、添加maven依赖​
<!-- OSS的SDK依赖 -->
<dependency>
<groupId>com.aliyun.oss</groupId>
<artifactId>aliyun-sdk-oss</artifactId>
<version>3.10.2</version>
</dependency>
<!--fastjson工具-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.72</version>
</dependency>
​第二步、编写一个Controller​
import com.alibaba.fastjson.JSONObject;
import com.aliyun.oss.OSSClient;
import com.aliyun.oss.common.utils.BinaryUtil;
import com.aliyun.oss.model.MatchMode;
import com.aliyun.oss.model.PolicyConditions;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.io.UnsupportedEncodingException;
import java.sql.Date;
import java.time.LocalDate;
import java.util.LinkedHashMap;
import java.util.Map;

@RestController
public class OssController {

@GetMapping("/asign")
@CrossOrigin //开启跨域访问
public JSONObject policyAsign() {
String accessId = ""; // 请填写您的 AccessKeyId。
String accessKey = ""; // 请填写您的 AccessKeySecret。
String endpoint = ""; // 请填写您的 endpoint。
String bucket = ""; // 请填写您的 bucketname 。

String host = "http://" + bucket + "." + endpoint; // host的格式为 bucketname.endpoint
// callbackUrl为 上传回调服务器的URL,请将下面的IP和Port配置为您自己的真实信息。
TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));
String dir = LocalDate.now().toString();// 用户上传文件时指定的前缀。我这里设置日期为前缀
OSSClient client = new OSSClient(endpoint, accessId, accessKey);

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 = client.generatePostPolicy(expiration, policyConds);
byte[] binaryData = new byte[0];
try {
binaryData = postPolicy.getBytes("utf-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
String encodedPolicy = BinaryUtil.toBase64String(binaryData);
String postSignature = client.calculatePostSignature(postPolicy);

Map<String, Object> respMap = new LinkedHashMap<String, Object>();
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));

JSONObject jasonCallback = new JSONObject();
// jasonCallback.put("callbackUrl", callbackUrl);
jasonCallback.put("callbackBody",
"filename=${object}&size=${size}&mimeType=${mimeType}&height=${imageInfo.height}&width=${imageInfo.width}");
jasonCallback.put("callbackBodyType", "application/x-www-form-urlencoded");
String base64CallbackBody = BinaryUtil.toBase64String(jasonCallback.toString().getBytes());
respMap.put("callback", base64CallbackBody);

return new JSONObject(respMap);//将签名数据暴露出去

}
}
​第三步、启动springboot项目,将签名数据暴露出去​

通过​​controller​​得到签名后的数据

签名地址为 ​​服务器地址+端口+访问路径​​,例如​​​

第二步、​​axios​​上传文件到阿里OSS服务器

引入​​axios​

​官网中文文档地址​

cdn方式引入

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<el-upload
class="avatar-uploader"
:show-file-list="false"
:http-request="Uploadfile">
<img v-if="pictureUrl.trim()!=''" :src="pictureUrl" class="avatar">
<i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>

注意这里的​​:http-request="Uploadfile"​​使用的是这个方法上传文件

其中的img是上传后,判断是否获取到图片的url来显示图片。

需要有一个保存图片的url变量

<script type="text/javascript">
const vm = new Vue({ // 配置对象 options
// 配置选项(option)
el: '#app', // element: 指定用vue来管理页面中的哪个标签区域
data() {
return {
pictureUrl: ''
};
},
methods: {
//自己编写的函数用于生成文件名,防止上传的文件重名
getUUID() {
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {
return (c === 'x' ? (Math.random() * 16 | 0) : ('r&0x3' | '0x8')).toString(16)
})
},

Uploadfile(param) {
let file = param.file; // 得到文件的内容
console.log(file);
//填写获取签名的地址
const getPolicyApiUrl = 'http://localhost:8088/asign'; //获取oss签名的地址
// 获取oss签名
axios({
method: 'get',
url: getPolicyApiUrl,
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Access-Control-Allow-Origin': '*',
}
}).then((response) => {
if (response.status == 200) {
let policyData = response.data;
console.log(policyData);
/**
ossUrl 换成自己的Bucket的外网地址,
例如 https://human-resource-manage.oss-cn-shenzhen.aliyuncs.com
*/
let ossUrl = '';//填写自己OSS服务器的地址
let accessUrl = policyData.dir + '/' + this.getUUID() + file.name;//设置上传的访问路径
let sendData = new FormData();// 上传文件的data参数
sendData.append('OSSAccessKeyId', policyData.accessid);
sendData.append('policy', policyData.policy);
sendData.append('Signature', policyData.signature);
sendData.append('keys', policyData.dir);
sendData.append('key', accessUrl);//上传的文件路径
sendData.append('success_action_status', 200); // 指定返回的状态码
sendData.append('type', 'image/jpeg');
sendData.append('file', file);
console.log(sendData);
axios.post(ossUrl, sendData).then((res) => {
this.pictureUrl = ossUrl + '/' + accessUrl;//获得到的url需要将其存数据库中
console.log('上传到阿里云的图片地址:' + ossUrl + '/' + accessUrl)
})
}
})
},

}
})
</script>

完整的​​html​​代码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>用户个人信息管理页面</title>
<!-- cdn引入ElementUI样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<style>
html, body {
width: 100%;
height: 100%;
margin: 0;
}

.avatar-uploader .el-upload {
border: 1px dashed #d9d9d9;
border-radius: 6px;
cursor: pointer;
position: relative;
overflow: hidden;
}

.avatar-uploader .el-upload:hover {
border-color: #409EFF;
}

.avatar-uploader-icon {
font-size: 28px;
color: #8c939d;
width: 178px;
height: 178px;
line-height: 178px;
text-align: center;
}

.avatar {
width: 178px;
height: 178px;
display: block;
}
</style>
</head>
<body>
<div id="app" style="height: 100%">
<div>
<el-upload
class="avatar-uploader"
:show-file-list="false"
:http-request="Uploadfile">
<img v-if="pictureUrl.trim()!=''" :src="pictureUrl" class="avatar">
<i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>
</div>
</div>

<!--cdn引入ElementUI组件必须先引入Vue-->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<!-- cdn引入ElementUI组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
<!--cdn引入axios-->
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

<script type="text/javascript">
const vm = new Vue({ // 配置对象 options
// 配置选项(option)
el: '#app', // element: 指定用vue来管理页面中的哪个标签区域
data() {
return {
pictureUrl: ''
};
},
methods: {
//自己编写的函数用于生成文件名,防止上传的文件重名
getUUID() {
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {
return (c === 'x' ? (Math.random() * 16 | 0) : ('r&0x3' | '0x8')).toString(16)
})
},

Uploadfile(param) {
let file = param.file; // 得到文件的内容
console.log(file);
//填写获取签名的地址
const getPolicyApiUrl = 'http://localhost:8088/asign'; //获取oss签名的地址
// 获取oss签名
axios({
method: 'get',
url: getPolicyApiUrl,
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Access-Control-Allow-Origin': '*',
}
}).then((response) => {
if (response.status == 200) {
let policyData = response.data;
console.log(policyData);
/**
ossUrl 换成自己的Bucket的外网地址,
例如 https://human-resource-manage.oss-cn-shenzhen.aliyuncs.com
*/
let ossUrl = 'https://human-resource-manage.oss-cn-shenzhen.aliyuncs.com';//填写自己OSS服务器的地址
let accessUrl = policyData.dir + '/' + this.getUUID() + file.name;//设置上传的访问路径
let sendData = new FormData();// 上传文件的data参数
sendData.append('OSSAccessKeyId', policyData.accessid);
sendData.append('policy', policyData.policy);
sendData.append('Signature', policyData.signature);
sendData.append('keys', policyData.dir);
sendData.append('key', accessUrl);//上传的文件路径
sendData.append('success_action_status', 200); // 指定返回的状态码
sendData.append('type', 'image/jpeg');
sendData.append('file', file);
console.log(sendData);
axios.post(ossUrl, sendData).then((res) => {
this.pictureUrl = ossUrl + '/' + accessUrl;//获得到的url需要将其存数据库中
console.log('上传到阿里云的图片地址:' + ossUrl + '/' + accessUrl)
})
}
})
},

}
})
</script>


</body>
</html>

如下图

使用ElementUi中的el-upload组件,后台服务器签名,前端直传阿里云OSS。_ios_05