2019-10-15 16:14:05 +08:00
|
|
|
---
|
|
|
|
order: 11
|
|
|
|
title:
|
|
|
|
zh-CN: 阿里云 OSS
|
|
|
|
en-US: Aliyun OSS
|
|
|
|
---
|
|
|
|
|
|
|
|
## zh-CN
|
|
|
|
|
|
|
|
使用阿里云 OSS 上传示例.
|
|
|
|
|
|
|
|
## en-US
|
|
|
|
|
|
|
|
Use Aliyun OSS upload example.
|
|
|
|
|
|
|
|
```jsx
|
2019-10-16 10:44:56 +08:00
|
|
|
import { Form, Upload, message, Button } from 'antd';
|
2019-11-28 12:34:33 +08:00
|
|
|
import { UploadOutlined } from '@ant-design/icons';
|
2019-10-15 16:14:05 +08:00
|
|
|
|
|
|
|
class AliyunOSSUpload extends React.Component {
|
|
|
|
state = {
|
|
|
|
OSSData: {},
|
|
|
|
};
|
|
|
|
|
|
|
|
async componentDidMount() {
|
|
|
|
await this.init();
|
|
|
|
}
|
|
|
|
|
|
|
|
init = async () => {
|
|
|
|
try {
|
|
|
|
const OSSData = await this.mockGetOSSData();
|
|
|
|
|
|
|
|
this.setState({
|
|
|
|
OSSData,
|
|
|
|
});
|
|
|
|
} catch (error) {
|
|
|
|
message.error(error);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// Mock get OSS api
|
|
|
|
// https://help.aliyun.com/document_detail/31988.html
|
2020-12-09 17:12:32 +08:00
|
|
|
mockGetOSSData = () => ({
|
|
|
|
dir: 'user-dir/',
|
|
|
|
expire: '1577811661',
|
|
|
|
host: '//www.mocky.io/v2/5cc8019d300000980a055e76',
|
|
|
|
accessId: 'c2hhb2RhaG9uZw==',
|
|
|
|
policy: 'eGl4aWhhaGFrdWt1ZGFkYQ==',
|
|
|
|
signature: 'ZGFob25nc2hhbw==',
|
|
|
|
});
|
2019-10-15 16:14:05 +08:00
|
|
|
|
|
|
|
onChange = ({ fileList }) => {
|
|
|
|
const { onChange } = this.props;
|
|
|
|
console.log('Aliyun OSS:', fileList);
|
|
|
|
if (onChange) {
|
|
|
|
onChange([...fileList]);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
onRemove = file => {
|
|
|
|
const { value, onChange } = this.props;
|
|
|
|
|
|
|
|
const files = value.filter(v => v.url !== file.url);
|
|
|
|
|
|
|
|
if (onChange) {
|
|
|
|
onChange(files);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
getExtraData = file => {
|
|
|
|
const { OSSData } = this.state;
|
|
|
|
|
|
|
|
return {
|
|
|
|
key: file.url,
|
|
|
|
OSSAccessKeyId: OSSData.accessId,
|
|
|
|
policy: OSSData.policy,
|
|
|
|
Signature: OSSData.signature,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-12-15 15:56:35 +08:00
|
|
|
beforeUpload = async file => {
|
2019-10-15 16:14:05 +08:00
|
|
|
const { OSSData } = this.state;
|
|
|
|
const expire = OSSData.expire * 1000;
|
|
|
|
|
|
|
|
if (expire < Date.now()) {
|
|
|
|
await this.init();
|
|
|
|
}
|
2020-12-15 15:56:35 +08:00
|
|
|
|
|
|
|
const suffix = file.name.slice(file.name.lastIndexOf('.'));
|
|
|
|
const filename = Date.now() + suffix;
|
|
|
|
file.url = OSSData.dir + filename;
|
|
|
|
|
|
|
|
return file;
|
2019-10-15 16:14:05 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { value } = this.props;
|
|
|
|
const props = {
|
|
|
|
name: 'file',
|
|
|
|
fileList: value,
|
|
|
|
action: this.state.OSSData.host,
|
|
|
|
onChange: this.onChange,
|
|
|
|
onRemove: this.onRemove,
|
|
|
|
data: this.getExtraData,
|
|
|
|
beforeUpload: this.beforeUpload,
|
|
|
|
};
|
|
|
|
return (
|
|
|
|
<Upload {...props}>
|
2020-08-24 16:33:24 +08:00
|
|
|
<Button icon={<UploadOutlined />}>Click to Upload</Button>
|
2019-10-15 16:14:05 +08:00
|
|
|
</Upload>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-20 09:48:26 +08:00
|
|
|
const App = () => (
|
2019-10-16 10:46:33 +08:00
|
|
|
<Form labelCol={{ span: 4 }}>
|
|
|
|
<Form.Item label="Photos" name="photos">
|
|
|
|
<AliyunOSSUpload />
|
|
|
|
</Form.Item>
|
|
|
|
</Form>
|
|
|
|
);
|
2019-10-15 16:14:05 +08:00
|
|
|
|
2022-04-20 09:48:26 +08:00
|
|
|
export default App;
|
2019-10-15 16:14:05 +08:00
|
|
|
```
|