diff --git a/documents/help/oss/obtain-signature-information-from-the-server-and-upload-data-to-oss.yml b/documents/help/oss/obtain-signature-information-from-the-server-and-upload-data-to-oss.yml
index 01f42075..50fc288f 100644
--- a/documents/help/oss/obtain-signature-information-from-the-server-and-upload-data-to-oss.yml
+++ b/documents/help/oss/obtain-signature-information-from-the-server-and-upload-data-to-oss.yml
@@ -13,6 +13,13 @@ Parameters:
is 3~63 characters. Must start and end with a lowercase English letter or
number, and can contain lowercase English letters, numbers, and dashes (-).
zh-cn: Bucket 名称在 OSS 范围内必须全局唯一。长度为3~63个字符。必须以小写英文字母或数字开头和结尾,可包含小写英文字母、数字和短划线(-)。
+ AssociationProperty: AutoCompleteInput
+ AssociationPropertyMetadata:
+ Length: 6
+ Prefix: testbucketname-
+ CharacterClasses:
+ - Class: lowercase
+ min: 1
AllowedPattern: ^[a-z0-9][a-z0-9-]{1,61}[a-z0-9]$
ZoneId:
Type: String
@@ -52,7 +59,7 @@ Parameters:
It must consist three of the the following character types: uppercase letters, lowercase letters, digits, and special characters.
Special characters include ()`~!@#$%^&*_-+=|{}[]:;'<>,.?/.
zh-cn: 长度为8-30位,需包含大写字母、小写字母、特殊符号和数字中的三个,允许的特殊字符包括()`~!@#$%^&*_-+=|{}[]:;'<>,.?/。
- Default: null
+ Default: Null
AllowedPattern: '[0-9A-Za-z\_\-&:;''<>,=%`~!@#\(\)\$\^\*\+\|\{\}\[\]\.\?\/]+$'
MinLength: 8
MaxLength: 30
@@ -83,12 +90,12 @@ Resources:
DeletionForce: true
CORSConfiguration:
CORSRule:
- - AllowedHeader:
- - '*'
- AllowedMethod:
- - POST
- AllowedOrigin:
- - '*'
+ - AllowedHeader:
+ - '*'
+ AllowedMethod:
+ - POST
+ AllowedOrigin:
+ - '*'
InstanceGroup:
Type: ALIYUN::ECS::InstanceGroup
Properties:
@@ -119,14 +126,14 @@ Resources:
Properties:
InstanceId:
Fn::Select:
- - 0
- - Fn::GetAtt:
- - InstanceGroup
- - InstanceIds
+ - 0
+ - Fn::GetAtt:
+ - InstanceGroup
+ - InstanceIds
AllocationId:
Fn::GetAtt:
- - Eip
- - AllocationId
+ - Eip
+ - AllocationId
SecurityGroupIngress_22:
Type: ALIYUN::ECS::SecurityGroupIngress
Properties:
@@ -136,16 +143,7 @@ Resources:
IpProtocol: tcp
NicType: intranet
PortRange: 22/22
- SecurityGroupIngress_80:
- Type: ALIYUN::ECS::SecurityGroupIngress
- Properties:
- SecurityGroupId:
- Ref: SecurityGroup
- SourceCidrIp: 0.0.0.0/0
- IpProtocol: tcp
- NicType: intranet
- PortRange: 80/80
- SecurityGroupIngress_443:
+ SecurityGroupIngress_3001:
Type: ALIYUN::ECS::SecurityGroupIngress
Properties:
SecurityGroupId:
@@ -153,135 +151,90 @@ Resources:
SourceCidrIp: 0.0.0.0/0
IpProtocol: tcp
NicType: intranet
- PortRange: 443/443
- SecurityGroupIngress_8080:
- Type: ALIYUN::ECS::SecurityGroupIngress
- Properties:
- SecurityGroupId:
- Ref: SecurityGroup
- SourceCidrIp: 0.0.0.0/0
- IpProtocol: tcp
- NicType: intranet
- PortRange: 8080/8080
+ PortRange: 3001/3001
ServerCommand:
Type: ALIYUN::ECS::RunCommand
Properties:
InstanceIds:
Fn::GetAtt:
- - InstanceGroup
- - InstanceIds
+ - InstanceGroup
+ - InstanceIds
Type: RunShellScript
Sync: true
Timeout: 3600
CommandContent:
Fn::Sub: |-
#!/bin/bash
- yum -y install unzip python3 nginx
- wget -O aliyun-oss-appserver-python-master.zip 'https://docs-aliyun.cn-hangzhou.oss.aliyun-inc.com/assets/attach/97721/cn_zh/1545016122500/aliyun-oss-appserver-python-master.zip?file=aliyun-oss-appserver-python-master.zip'
- unzip -o aliyun-oss-appserver-python-master.zip && mv aliyun-oss-appserver-python-preview_1.0.1-2f62c60e04b4ff204320adf47ded9d83fd79e826/* .
- rm -rf aliyun-oss-appserver-python-preview_1.0.1-2f62c60e04b4ff204320adf47ded9d83fd79e826
- sed -i 's//${AccessKey.AccessKeyId}/g' appserver.py
- sed -i 's//${AccessKey.AccessKeySecret}/g' appserver.py
- sed -i 's/bucket-name.oss-cn-hangzhou.aliyuncs.com/${BucketName}.oss-${ALIYUN::Region}.aliyuncs.com/g' appserver.py
- sed -i 's/expire_syncpoint = 1612345678/# expire_syncpoint = 1612345678/g' appserver.py
- touch runserver.sh && cat > runserver.sh << EOF
- pip3 uninstall crypto
- pip3 uninstall pycrypto
- pip3 install pycryptodome
- nohup python3 appserver.py &
+ yum -y install unzip
+
+ curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
+ source /root/.bashrc
+ nvm install 16
+
+ wget -O server-signed-direct-upload.zip 'https://peiyu-demo-bucket.oss-cn-beijing.aliyuncs.com/server-signed-direct-upload.zip'
+ unzip -o server-signed-direct-upload.zip
+ rm -rf server-signed-direct-upload.zip
+ cat > /root/server-signed-direct-upload/node-html-post-object/server/config.js << EOF
+ module.exports = {
+ accessKeyId: "${AccessKey.AccessKeyId}",
+ accessKeySecret: "${AccessKey.AccessKeySecret}",
+ region: "oss-${ALIYUN::Region}",
+ bucket: "${Bucket.Name}",
+ roleArn: "${Role.Arn}",
+ };
EOF
- bash runserver.sh
-
- mkdir -p /var/www/html && cd /var/www/html
- wget -O aliyun-oss-appserver-js-master.zip 'https://docs-aliyun.cn-hangzhou.oss.aliyun-inc.com/assets/attach/86983/APP_zh/1537971352825/aliyun-oss-appserver-js-master.zip?file=aliyun-oss-appserver-js-master.zip'
- unzip aliyun-oss-appserver-js-master.zip
- cd aliyun-oss-appserver-js-master/
- sed -i 's|88.88.88.88:8888|${Eip.EipAddress}:8080|g' upload.js
- sed -i "s|'callback' : callbackbody|//'callback' : callbackbody|g" upload.js
-
- touch /etc/nginx/conf.d/oss-client.conf
- cat > /etc/nginx/conf.d/oss-client.conf << EOF
- server {
- listen 80 default_server;
- server_name _;
- location / {
- root /var/www/html/aliyun-oss-appserver-js-master;
- index index.html;
- }
- }
- EOF
- systemctl start nginx
+ sed -i 's/127.0.0.1/${Eip.EipAddress}/g' /root/server-signed-direct-upload/node-html-post-object/index.html
+ cd /root/server-signed-direct-upload/node-html-post-object/
+ source /root/.bashrc
+ nohup npm start > output.log 2>&1 &
DependsOn:
- - SecurityGroupIngress_22
- - SecurityGroupIngress_443
- - SecurityGroupIngress_80
- - SecurityGroupIngress_8080
+ - SecurityGroupIngress_3001
+ - SecurityGroupIngress_22
+ - EipAssociation
User:
Type: ALIYUN::RAM::User
Properties:
UserName:
- Fn::Sub: create_by_document-${ALIYUN::StackId}
+ Fn::Sub: user-create-by-${ALIYUN::StackId}
PolicyAttachments:
System:
- - AliyunOSSFullAccess
+ - AliyunSTSAssumeRoleAccess
AccessKey:
Type: ALIYUN::RAM::AccessKey
Properties:
UserName:
Ref: User
+ Role:
+ Type: ALIYUN::RAM::Role
+ Properties:
+ RoleName:
+ Fn::Sub: ram-oss-test-create-by-${ALIYUN::StackId}
+ AssumeRolePolicyDocument:
+ Statement:
+ - Action: sts:AssumeRole
+ Effect: Allow
+ Principal:
+ RAM:
+ - Fn::Sub: acs:ram::${ALIYUN::TenantId}:root
+ Version: '1'
+ Policies:
+ - PolicyName:
+ Fn::Sub: policy-create-by-${ALIYUN::StackId}
+ PolicyDocument:
+ Version: '1'
+ Statement:
+ - Effect: Allow
+ Action:
+ - oss:PutObject
+ Resource:
+ - Fn::Sub: acs:oss:*:*:${Bucket.Name}/*
Outputs:
OssClientAddress:
Description:
en: Client address, use this address to directly experience file upload.
zh-cn: 客户端地址,使用此地址可直接体验文件上传。
Value:
- Fn::Sub: http://${Eip.EipAddress}
- ApplicationServerAddress:
- Description:
- en: Application server address, configure this address in the local client source
- code to experience file upload locally.
- zh-cn: 应用服务端地址,在本地客户端源码中配置此地址可在本地体验文件上传。
- Value:
- Fn::Sub: ${Eip.EipAddress}:8080
- EcsInstanceId:
- Description:
- en: Ecs instance id.
- zh-cn: ECS实例id。
- Value:
- Fn::Select:
- - 0
- - Fn::GetAtt:
- - InstanceGroup
- - InstanceIds
- EipAllocationId:
- Description:
- en: Eip allocation id.
- zh-cn: EIP实例id。
- Value:
- Fn::GetAtt:
- - Eip
- - AllocationId
- OssBucketName:
- Description:
- en: Oss bucket name.
- zh-cn: 存储空间名称。
- Value:
- Ref: Bucket
- EcsLoginAddress:
- Description:
- en: Ecs login address.
- zh-cn: ECS登录地址。
- Value:
- Fn::Sub:
- - https://ecs-workbench.aliyun.com/?from=EcsConsole&instanceType=ecs®ionId=${Region}&instanceId=${InstanceId}
- - Region:
- Ref: ALIYUN::Region
- InstanceId:
- Fn::Select:
- - 0
- - Fn::GetAtt:
- - InstanceGroup
- - InstanceIds
+ Fn::Sub: http://${Eip.EipAddress}:3001/index.html
Metadata:
ALIYUN::ROS::Interface:
ParameterGroups:
@@ -292,4 +245,4 @@ Metadata:
- SystemDiskCategory
- Password
TemplateTags:
- - acs:document-help:oss:服务端签名后直传
+ - acs:document-help:oss:服务端签名后直传
\ No newline at end of file