通过PHP创建AWS的CloudFront并绑定证书添加备用域名

如果你要做一个动态绑定域名到AWS服务器的功能,那一定会经历以下事情:

1、申请证书

2、创建源S3(静态)或者EC2 (去后台手动操作)

3、创建CloudFront

4、绑定证书到CloudFront

5、添加备用域名

如果是你自己给自己的服务器添加域名,那这些操作都可以在AWS后台手动操作。

但现在我公司有一个需求,是提供服务器,让用户自己注册域名,并把自己注册的域名通过我们提供的后台去绑定到我们的服务器上,当然不能让用户登录我们的AWS后台操作了。这就需要我们提供API接口去动态操作上面的1,3,4,5步骤了。

申请证书API操作前面的文章已经说过了。这里就说怎么通过PHP的SDK创建CloudFront,绑定证书,添加备用域名了。

复制代码
require 'vendor/autoload.php';
 
use Aws\CloudFront\CloudFrontClient;
use Aws\Exception\AwsException;
use Aws\Iam\IamClient;
use Aws\CertificateManager\CertificateManagerClient;
 
// 配置AWS SDK
$awsConfig = [
    'version' => 'latest',
    'region'  => 'us-east-1'
];
 
$cloudFrontClient = new CloudFrontClient($awsConfig);
$iamClient = new IamClient($awsConfig);
$certificateManagerClient = new CertificateManagerClient($awsConfig);
 
// 创建发行版
try {
    $result = $cloudFrontClient->createDistribution([]);
    $distributionId = $result['Distribution']['Id'];
    echo "创建发行版成功,ID: " . $distributionId . "\n";
} catch (AwsException $e) {
    echo "创建发行版失败:" . $e->getMessage() . "\n";
    exit();
}
 
// 绑定证书
try {
    $certificateResult = $certificateManagerClient->listCertificates();
    $certificateArn = $certificateResult['CertificateSummarys'][0]['CertificateArn'];
 
    $result = $cloudFrontClient->updateDistribution([]);
    echo "证书绑定成功。\n";
} catch (AwsException $e) {
    echo "证书绑定失败:" . $e->getMessage() . "\n";
    exit();
}
 
// 添加备用域名
try {
    $result = $cloudFrontClient->updateDistribution([]);
    echo "备用域名添加成功。\n";
} catch (AwsException $e) {
    echo "备用域名添加失败:" . $e->getMessage() . "\n";
    exit();
}
相关推荐
杨云龙UP23 分钟前
ODA-Oracle实践记录:通过Navicat导出导入表CSV文件并清理重复数据,处理OA待办延迟刷新问题_20260416
linux·运维·服务器·数据库·sql·mysql·oracle
START_GAME1 小时前
SQL Server 还原 .bak 文件(SSMS 图形界面法)
运维·服务器·数据库
TG_yunshuguoji1 小时前
阿里云代理商:2026年云端与本地双轨部署OpenClaw 方案
服务器·阿里云·云计算·openclaw
楼田莉子2 小时前
Linux网络:IP协议
linux·服务器·网络·c++·学习·tcp/ip
极客on之路2 小时前
线上 JVM 出问题
运维·服务器·jvm
阿林爱吃大米饭2 小时前
[AutoDL] 预防系统盘爆满:一键将Conda环境和Pip缓存迁移到数据盘(autodl-tmp)
服务器
Ops菜鸟(Xu JieHao)2 小时前
Linux 内网远程桌面Xrdp ~保姆级教程
linux·运维·服务器·windows·远程桌面·远程·xrdp
zjeweler2 小时前
linux服务器部署openclaw最新最细教程(非docker版)
linux·服务器·docker·openclaw
AIBox3652 小时前
claude 镜像 api 使用指南(2026 年4 月更新)
java·服务器·前端·人工智能·gpt·前端框架
我材不敲代码2 小时前
PyQt5入门教程——简单实现一个登录界面
linux·运维·服务器