使用 Amazon SNS 发送 SMS 并获取投递状态

使用 amazon sns 发送 sms 并获取投递状态

本文档介绍了如何使用 Amazon SNS 服务通过 PHP SDK 发送 SMS 消息,并详细阐述了如何通过 CloudWatch API 获取 SMS 消息的投递状态,以便开发者能够监控消息发送结果并及时处理异常。

Amazon Simple Notification Service (SNS) 是一种快速、灵活、完全托管的推送消息服务。您可以使用 SNS 发送消息到移动设备、电子邮件地址、其他 AWS 服务等。本教程将重点介绍如何使用 PHP SDK 发送 SMS 消息,并介绍如何获取消息的投递状态。

发送 SMS 消息

首先,确保您已经安装了 AWS PHP SDK。您可以使用 Composer 进行安装:

composer require aws/aws-sdk-php

接下来,使用以下代码发送 SMS 消息:

 'eu-west-1', // 替换为您的 AWS 区域    'version' => 'latest',    'credentials' => [        'key'    => 'YOUR_AWS_ACCESS_KEY_ID', // 替换为您的 AWS 访问密钥 ID        'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY', // 替换为您的 AWS 秘密访问密钥    ]]);try {    $result = $sdk->publish([        'Message' => 'This is a test message.',        'PhoneNumber' => '+1234567890', // 替换为目标手机号码,包含国家码        'MessageAttributes' => [            'AWS.SNS.SMS.SenderID' => [                'DataType' => 'String',                'StringValue' => 'MySenderID' // 替换为您希望显示的发送者 ID (可选)            ]        ]    ]);    print_r($result);} catch (AwsExceptionAwsException $e) {    // 输出错误信息    echo 'Error: ' . $e->getMessage();}?>

代码解释:

require ‘vendor/autoload.php’;: 引入 Composer 自动加载器,加载 AWS PHP SDK。new AwsSnsSnsClient([…]): 创建 SNS 客户端实例,需要配置 AWS 区域、版本和凭证。$sdk->publish([…]): 调用 publish 方法发送 SMS 消息。Message: 消息内容。PhoneNumber: 目标手机号码,必须包含国家码。MessageAttributes: 消息属性,可以设置发送者 ID 等。try…catch: 捕获可能发生的 AWS 异常,并输出错误信息。

注意事项:

请确保您已配置正确的 AWS 区域和凭证。目标手机号码必须包含国家码。发送者 ID 是可选的,但某些国家/地区可能要求必须设置。您需要在 AWS 管理控制台中为您的 AWS 账户启用 SMS 发送功能。

获取投递状态

Amazon SNS 本身不直接提供回调 URL 用于接收投递状态。目前,获取 SMS 消息投递状态的主要方法是使用 Amazon CloudWatch Logs。SNS 会将 SMS 消息的投递日志发送到 CloudWatch Logs,您可以通过 CloudWatch API 查询这些日志。

步骤:

配置 SNS 将 SMS 消息日志发送到 CloudWatch Logs。 您需要在 AWS 管理控制台中配置 SNS,使其将 SMS 消息的日志发送到指定的 CloudWatch Logs 日志组。

使用 CloudWatch API 查询日志。 您可以使用 AWS PHP SDK 中的 CloudWatch Logs 客户端查询日志。

以下是一个使用 CloudWatch Logs API 获取日志事件的示例代码:

 'eu-west-1', // 替换为您的 AWS 区域    'version' => 'latest',    'credentials' => [        'key'    => 'YOUR_AWS_ACCESS_KEY_ID', // 替换为您的 AWS 访问密钥 ID        'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY', // 替换为您的 AWS 秘密访问密钥    ]]);$logGroupName = '/aws/sns/sms'; // 替换为您的 CloudWatch Logs 日志组名称$logStreamName = 'YourLogStreamName'; // 可选,如果知道具体的日志流名称,可以指定try {    $result = $client->getLogEvents([        'logGroupName' => $logGroupName,        //'logStreamName' => $logStreamName, // 可选        'startTime' => strtotime('-1 hour') * 1000, // 查询过去一小时内的日志        'endTime' => time() * 1000,        'limit' => 100, // 限制返回的日志事件数量        'startFromHead' => true, // 从日志流的开头开始读取    ]);    foreach ($result['events'] as $event) {        echo $event['message'] . "n";        // 在这里解析日志消息,提取投递状态信息    }} catch (AwsExceptionAwsException $e) {    echo 'Error: ' . $e->getMessage();}?>

代码解释:

new AwsCloudWatchLogsCloudWatchLogsClient([…]): 创建 CloudWatch Logs 客户端实例,需要配置 AWS 区域、版本和凭证。$client->getLogEvents([…]): 调用 getLogEvents 方法查询日志事件。logGroupName: CloudWatch Logs 日志组名称。logStreamName: 可选,如果知道具体的日志流名称,可以指定。startTime: 查询的起始时间,Unix 时间戳(毫秒)。endTime: 查询的结束时间,Unix 时间戳(毫秒)。limit: 限制返回的日志事件数量。startFromHead: 从日志流的开头开始读取。foreach ($result[‘events’] as $event): 遍历返回的日志事件,并解析日志消息,提取投递状态信息。

注意事项:

请确保您已配置正确的 AWS 区域和凭证。您需要根据实际情况修改 logGroupName 和 logStreamName。日志消息的格式可能因 SNS 配置而异,您需要根据实际情况解析日志消息。可以使用更复杂的过滤条件,例如使用 filterPattern 参数,来更精确地查询日志。

总结:

虽然 Amazon SNS 不直接提供回调 URL 用于接收投递状态,但您可以使用 CloudWatch Logs API 查询 SMS 消息的投递日志,从而获取投递状态信息。 这种方法需要您配置 SNS 将日志发送到 CloudWatch Logs,并编写代码来查询和解析日志。 通过这种方式,您可以有效地监控 SMS 消息的发送结果并及时处理异常。

以上就是使用 Amazon SNS 发送 SMS 并获取投递状态的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1325219.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 11:48:40
下一篇 2025年12月12日 11:48:45

相关推荐

  • 如何使用 Laravel 框架轻松整合微信支付与支付宝支付?

    如何通过 laravel 框架整合微信支付与支付宝支付 在 laravel 开发中,为电商网站或应用程序整合支付网关至关重要。其中,微信支付和支付宝是中国最流行的支付平台。本文将介绍如何使用 laravel 框架封装这两大支付平台。 一个简单有效的方法是使用业内认可的 easywechat lara…

    2025年12月24日
    000
  • Laravel 框架中如何无缝集成微信支付和支付宝支付?

    laravel 框架中微信支付和支付宝支付的封装 如何将微信支付和支付宝支付无缝集成到 laravel 框架中? 建议解决方案 考虑使用 easywechat 的 laravel 版本。easywechat 是一个成熟、维护良好的库,由腾讯官方人员开发,专为处理微信相关功能而设计。其 laravel…

    2025年12月24日
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 使用Laravel框架如何整合微信支付和支付宝支付?

    使用 Laravel 框架整合微信支付和支付宝支付 在使用 Laravel 框架开发项目时,整合支付网关是常见的需求。对于微信支付和支付宝支付,推荐采用以下方法: 使用第三方库:EasyWeChat 的 Laravel 版本 建议直接使用现有的 EasyWeChat 的 Laravel 版本。该库由…

    2025年12月24日
    000
  • 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中?

    如何简洁集成微信和支付宝支付到 Laravel 问题: 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中? 答案: 强烈推荐使用流行的 Laravel 包 EasyWeChat,它由腾讯开发者维护。多年来,它一直保持更新,提供了一个稳定可靠的解决方案。 集成步骤: 安装 Laravel …

    2025年12月24日
    100
  • 使用 React 构建 Fylo 云存储网站

    介绍 在这篇博文中,我们将逐步介绍如何使用 react 创建一个功能丰富的云存储网站。该网站受 fylo 启发,提供了主页、功能、工作原理、感言和页脚等部分。在此过程中,我们将讨论用于构建这个完全响应式网站的结构、组件和样式。 项目概况 该项目由多个部分组成,旨在展示云存储服务。每个部分都是用 re…

    2025年12月24日 好文分享
    000
  • 使用 React 构建食谱查找器网站

    介绍 在本博客中,我们将使用 react 构建一个食谱查找网站。该应用程序允许用户搜索他们最喜欢的食谱,查看趋势或新食谱,并保存他们最喜欢的食谱。我们将利用 edamam api 获取实时食谱数据并将其动态显示在网站上。 项目概况 食谱查找器允许用户: 按名称搜索食谱。查看趋势和新添加的食谱。查看各…

    2025年12月24日 好文分享
    200
  • 不可变数据结构:ECMA 4 中的记录和元组

    不可变数据结构:ecmascript 2024 中的新功能 ecmascript 2024 引入了几个令人兴奋的更新,但对我来说最突出的一个功能是引入了不可变数据结构。这些新结构——记录和元组——改变了 javascript 中数据管理的游戏规则。它们提供了一种令人满意的方式来保持我们的数据健全、安…

    2025年12月24日
    100
  • 网页设计css样式代码大全,快来收藏吧!

    减少很多不必要的代码,html+css可以很方便的进行网页的排版布局。小伙伴们收藏好哦~ 一.文本设置    1、font-size: 字号参数  2、font-style: 字体格式 3、font-weight: 字体粗细 4、颜色属性 立即学习“前端免费学习笔记(深入)”; color: 参数 …

    2025年12月24日
    000
  • css中id选择器和class选择器有何不同

    之前的文章《什么是CSS语法?详细介绍使用方法及规则》中带了解CSS语法使用方法及规则。下面本篇文章来带大家了解一下CSS中的id选择器与class选择器,介绍一下它们的区别,快来一起学习吧!! id选择器和class选择器介绍 CSS中对html元素的样式进行控制是通过CSS选择器来完成的,最常用…

    2025年12月24日
    000
  • php约瑟夫问题如何解决

    “约瑟夫环”是一个数学的应用问题:一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数, 再数到第m只,在把它踢出去…,如此不停的进行下去, 直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。…

    好文分享 2025年12月24日
    000
  • CSS新手整理的有关CSS使用技巧

    [导读]  1、不要使用过小的图片做背景平铺。这就是为何很多人都不用 1px 的原因,这才知晓。宽高 1px 的图片平铺出一个宽高 200px 的区域,需要 200*200=40, 000 次,占用资源。  2、无边框。推荐的写法是     1、不要使用过小的图片做背景平铺。这就是为何很多人都不用 …

    好文分享 2025年12月23日
    000
  • CSS中实现图片垂直居中方法详解

    [导读] 在曾经的 淘宝ued 招聘 中有这样一道题目:“使用纯css实现未知尺寸的图片(但高宽都小于200px)在200px的正方形容器中水平和垂直居中。”当然出题并不是随意,而是有其现实的原因,垂直居中是 淘宝 工作中最 在曾经的 淘宝UED 招聘 中有这样一道题目: “使用纯CSS实现未知尺寸…

    好文分享 2025年12月23日
    000
  • CSS派生选择器

    [导读] 派生选择器通过依据元素在其位置的上下文关系来定义样式,你可以使标记更加简洁。在 css1 中,通过这种方式来应用规则的选择器被称为上下文选择器 (contextual selectors),这是由于它们依赖于上下文关系来应 派生选择器 通过依据元素在其位置的上下文关系来定义样式,你可以使标…

    好文分享 2025年12月23日
    000
  • CSS 基础语法

    [导读] css 语法 css 规则由两个主要的部分构成:选择器,以及一条或多条声明。selector {declaration1; declaration2;     declarationn }选择器通常是您需要改变样式的 html 元素。每条声明由一个属性和一个 CSS 语法 CSS 规则由两…

    2025年12月23日
    300
  • CSS 高级语法

    [导读] 选择器的分组你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明。用逗号将需要分组的选择器分开。在下面的例子中,我们对所有的标题元素进行了分组。所有的标题元素都是绿色的。h1,h2,h3,h4,h5 选择器的分组 你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明…

    好文分享 2025年12月23日
    000
  • CSS id 选择器

    [导读] id 选择器id 选择器可以为标有特定 id 的 html 元素指定特定的样式。id 选择器以 ” ” 来定义。下面的两个 id 选择器,第一个可以定义元素的颜色为红色,第二个定义元素的颜色为绿色: red {color:re id 选择器 id 选择器可以为标有特…

    好文分享 2025年12月23日
    000
  • 有关css的绝对定位

    [导读] 定位(左边和顶部) css定位属性将是网虫们打开幸福之门的钥匙: h4 { position: absolute; left: 100px; top: 43px }这项css规则让浏览器将 的起始位置精 确地定在距离浏览器左边100象素,距离其 定位(左边和顶部) css定位属性将是网虫们…

    好文分享 2025年12月23日
    000
  • html5怎么加php_html5用Ajax与PHP后端交互实现数据传递【交互】

    HTML5不能直接运行PHP,需通过Ajax与PHP通信:前端用fetch发送请求,PHP接收处理并返回JSON,前端解析响应更新DOM;注意跨域、编码、CSRF防护和输入过滤。 HTML5 本身是前端标记语言,不能直接运行 PHP 代码,但可以通过 Ajax(异步 JavaScript)与 PHP…

    2025年12月23日
    300
  • html5怎么设置单选_html5用input type=”radio”加name设单选按钮组【设置】

    HTML5 使用 type=”radio” 实现单选功能,需统一 name 值构成互斥组;通过 checked 设默认项;可用 CSS 隐藏原生控件并自定义样式;推荐用 fieldset/legend 增强语义;required 可实现必填验证。 如果您希望在网页中创建一组互…

    2025年12月23日
    200

发表回复

登录后才能评论
关注微信