我正在尝试连接到自定义的s3服务器(不是基于aws)并创建bucket。
在python中使用以下代码可以工作:
session = boto3.session.Session()
s3res = session.resource(service_name='s3',
use_ssl=True,
verify=False,
aws_access_key_id='xxx',
aws_secret_access_key='xxx',
endpoint_url='https://xxx',
config=botocore_client_config)
但是,node.js中的以下代码没有:
const AWS = require("aws-sdk");
const https = require('https');
const S3 = new AWS.S3({
accessKeyId: 'xxx',
secretAccessKey: 'xxx',
endpoint: 'https://xxx/',
s3ForcePathStyle: true,
httpOptions: {
agent: new https.Agent({ rejectUnauthorized: false })
}
});
实际上,在尝试创建bucket时会导致以下错误:
{ NetworkingError: Protocol "http:" not supported. Expected "https:"
at new ClientRequest (_http_client.js:109:11)
at Object.request (http.js:41:10)
at features.constructor.handleRequest (/home/ec2-user/s3-tests/node_modules/aws-sdk/lib/http/node.js:42:23)
如果删除自定义https代理,将出现以下错误:
{ Error: self signed certificate
at TLSSocket.onConnectSecure (_tls_wrap.js:1048:34)
此外,设置
process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";
也没有帮助。 最佳答案
看起来节点版本缺少s3选项中的sslEnabled: false
。