兰空图床使用 AWS s3 协议连接 backblaze b2
AWS s3 的 sdk 中,默认存在 ACL 配置,参数值默认为 private,因为 b2 控制台中没有 ACL 设置,使用公开的 bucket 会出现错误:Cannot parse S3 Canned ACL value of 'private',所以需要稍微修改点代码,覆盖 ACL 配置。
打开文件:
// 文件路径:lsky-pro/app/Services/ImageService.php
bucket: $configs->get(MinioOption::Bucket),
在 356 行下面追加一行:
options: ['params' => ['ACL' => '']],

示例:
StrategyKey::Minio => new AwsS3V3Adapter(
// ...
bucket: $configs->get(MinioOption::Bucket),
options: ['params' => ['ACL' => '']], // <-- 这里是新增的一行
// ...
),
然后在创建储存策略时,选择 Minio 进行配置即可,以下是配置示例:

其中的 Bucket、连接地址和区域,可以在 b2 控制台创建 Backet 以后找到,AccessKey 和 SecretKey 便是控制台中 App Key 中创建的前面,key ID = AccessKey,applicationKey = Secret Key。
注意:
- 不要使用 Master Application Key,它不兼容 S3 协议。
- 在 2020 年 5 月 4 日之前创建的桶不支持 s3 协议。
