通过 Amazon SNS 发送 SMS 并获取投递状态

通过 amazon sns 发送 sms 并获取投递状态

本文介绍了如何使用 Amazon SNS 服务通过 PHP SDK 发送 SMS 消息,并重点讲解了如何利用 CloudWatch API 获取 SMS 消息的投递状态,包括成功或失败的信息。通过监控 CloudWatch 日志,开发者可以实时追踪 SMS 消息的发送情况,从而更好地管理和优化短信服务。

Amazon Simple Notification Service (SNS) 是一种快速、灵活、完全托管的推送消息服务,可以用于发送 SMS 消息。然而,直接通过 SNS 获取 SMS 投递状态并非直接可行。本文将介绍如何利用 Amazon CloudWatch API 来间接获取 SMS 消息的投递状态。

使用 Amazon SNS 发送 SMS

首先,我们需要使用 Amazon PHP SDK 来发送 SMS 消息。以下是一个示例代码:

 'eu-west-1', // 替换为你的 AWS 区域    'version' => 'latest',    'credentials' => [        'key' => 'YOUR_AWS_ACCESS_KEY_ID', // 替换为你的 AWS Access Key ID        'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY' // 替换为你的 AWS Secret Access Key    ]]);$result = $sdk->publish([    'Message' => 'This is a test message.',    'PhoneNumber' => '+123456789', // 替换为你的目标电话号码,包含国家码    'MessageAttributes' => [        'AWS.SNS.SMS.SenderID' => [            'DataType' => 'String',            'StringValue' => 'MySenderID' // 可选,替换为你的自定义 Sender ID        ]    ]]);print_r( $result );?>

代码解释:

引入 SDK: require ‘vendor/autoload.php’; 引入 Composer 自动加载器,确保可以使用 AWS PHP SDK。创建 SNS 客户端: new AwsSnsSnsClient([…]) 创建一个 SNS 客户端实例,需要配置 AWS 区域、版本和凭证。publish() 方法: $sdk->publish([…]) 调用 publish() 方法发送 SMS 消息。Message: SMS 消息的内容。PhoneNumber: 接收 SMS 消息的电话号码,必须包含国家码。MessageAttributes: 可选参数,用于设置消息属性,例如 SenderID。

注意事项:

确保已安装 AWS PHP SDK。可以使用 Composer 安装:composer require aws/aws-sdk-php替换 YOUR_AWS_ACCESS_KEY_ID 和 YOUR_AWS_SECRET_ACCESS_KEY 为你的 AWS 凭证。替换 eu-west-1 为你的 AWS 区域。电话号码必须包含国家码,例如 +123456789。SenderID 是可选的,但建议设置,以便接收者可以识别消息来源。

获取 SMS 投递状态

虽然 SNS 本身不直接提供投递状态的回调 URL,但我们可以通过 CloudWatch Logs 来获取这些信息。

步骤:

启用 SNS 消息投递状态日志: 在 AWS 控制台中,进入 SNS 服务,选择你的 SNS 主题,找到 “Delivery status logging” 部分,启用 SMS 消息的日志记录。你需要指定一个 IAM 角色,该角色需要具有写入 CloudWatch Logs 的权限。

使用 CloudWatch API 获取日志事件: 使用 CloudWatch API (例如 GetLogEvents) 来读取日志组中的日志。

以下是一个使用 AWS PHP SDK 获取 CloudWatch Logs 的示例代码:

 'eu-west-1', // 替换为你的 AWS 区域    'version' => 'latest',    'credentials' => [        'key' => 'YOUR_AWS_ACCESS_KEY_ID', // 替换为你的 AWS Access Key ID        'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY' // 替换为你的 AWS Secret Access Key    ]]);$logGroupName = '/aws/sns/sms-deliveries'; // SNS SMS 投递状态日志组名称$logStreamName = 'YourLogStreamName'; // 替换为你的日志流名称,可以通过查询CloudWatch Logs找到$result = $client->getLogEvents([    'logGroupName' => $logGroupName,    'logStreamName' => $logStreamName,    'startFromHead' => true, // 从日志流的开头开始读取    'limit' => 10 // 读取的最大日志事件数量]);foreach ($result['events'] as $event) {    echo $event['message'] . "n";    // 解析日志消息,获取投递状态    // 例如,可以使用 json_decode() 解析 JSON 格式的日志消息}?>

代码解释:

创建 CloudWatch Logs 客户端: new AwsCloudWatchLogsCloudWatchLogsClient([…]) 创建一个 CloudWatch Logs 客户端实例,需要配置 AWS 区域、版本和凭证。getLogEvents() 方法: $client->getLogEvents([…]) 调用 getLogEvents() 方法获取日志事件。logGroupName: SNS SMS 投递状态日志组的名称,通常为 /aws/sns/sms-deliveries。logStreamName: 日志流的名称。你需要在 CloudWatch Logs 中找到对应的日志流名称。 日志流名称通常包含日期信息。startFromHead: 设置为 true 表示从日志流的开头开始读取。limit: 读取的最大日志事件数量。解析日志消息: 遍历 $result[‘events’],每个 $event[‘message’] 包含一个日志消息。你需要解析这些消息来获取投递状态。 SNS SMS 投递状态日志通常是 JSON 格式。

注意事项:

确保已安装 AWS PHP SDK。替换 YOUR_AWS_ACCESS_KEY_ID 和 YOUR_AWS_SECRET_ACCESS_KEY 为你的 AWS 凭证。替换 eu-west-1 为你的 AWS 区域。替换 YourLogStreamName 为你的日志流名称。你需要根据 SNS 的日志格式来解析日志消息,提取投递状态信息。

总结

通过以上步骤,你可以使用 Amazon SNS 发送 SMS 消息,并利用 CloudWatch API 获取 SMS 消息的投递状态。 虽然这种方法不如直接的回调 URL 方便,但它是目前获取 SNS SMS 投递状态的主要方式。 你需要定期查询 CloudWatch Logs,并解析日志消息,才能实时监控 SMS 消息的发送情况。 此外,需要注意 IAM 角色权限的配置,确保 SNS 可以写入 CloudWatch Logs,并且你的应用程序可以读取 CloudWatch Logs。

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

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 11:55:25
下一篇 2025年12月12日 11:55:38

相关推荐

  • 如何使用 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框架与JS之间的关系

    深入理解CSS框架与JS之间的关系 在现代web开发中,CSS框架和JavaScript (JS) 是两个常用的工具。CSS框架通过提供一系列样式和布局选项,可以帮助我们快速构建美观的网页。而JS则提供了一套功能强大的脚本语言,可以为网页添加交互和动态效果。本文将深入探讨CSS框架和JS之间的关系,…

    2025年12月24日
    000
  • HTML+CSS+JS实现雪花飘扬(代码分享)

    使用html+css+js如何实现下雪特效?下面本篇文章给大家分享一个html+css+js实现雪花飘扬的示例,希望对大家有所帮助。 很多南方的小伙伴可能没怎么见过或者从来没见过下雪,今天我给大家带来一个小Demo,模拟了下雪场景,首先让我们看一下运行效果 可以点击看看在线运行:http://hai…

    2025年12月24日 好文分享
    500
  • 10款好看且实用的文字动画特效,让你的页面更吸引人!

    图片和文字是网页不可缺少的组成部分,图片运用得当可以让网页变得生动,但普通的文字不行。那么就可以给文字添加一些样式,实现一下好看的文字效果,让页面变得更交互,更吸引人。下面创想鸟就来给大家分享10款文字动画特效,好看且实用,快来收藏吧! 1、网页玻璃文字动画特效 模板简介:使用css3制作网页渐变底…

    2025年12月24日 好文分享
    000
  • tp5如何引入css文件

    tp5引入css文件的方法:1、将css文件放在public目录下的static文件里即可;2、在页面引入中写上“”语句即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 其实很简单,只需要将css,js,image文件放在这个目录下即可 页…

    2025年12月24日
    000
  • 网页设计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
  • 聊聊CSS 与 JS 是如何阻塞 DOM 解析和渲染的

    本篇文章给大家介绍一下css和js阻塞 dom 解析和渲染的原理。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 hello~各位亲爱的看官老爷们大家好。估计大家都听过,尽量将CSS放头部,JS放底部,这样可以提高页面的性能。然而,为什么呢?大家有考虑过么?很长一段时间,我都是知其…

    2025年12月24日
    200
  • js如何修改css样式

    js修改css样式的方法:1、使用【obj.className】来修改样式表的类名;2、使用【obj.style.cssTest】来修改嵌入式的css;3、使用【obj.className】来修改样式表的类名;4、使用更改外联的css。 本教程操作环境:windows7系统、css3版,DELL G…

    2025年12月24日
    000
  • 如何使用纯CSS、JS实现图片轮播效果

    本篇文章给大家详细介绍一下使用纯css、js实现图片轮播效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 .carousel {width: 648px;height: 400px;margin: 0 auto;text-align: center;position: a…

    2025年12月24日
    000
  • js如何修改css

    js修改css的方法:1、使用【obj.style.cssTest】来修改嵌入式的css;2、使用【bj.className】来修改样式表的类名;3、使用更改外联的css文件,从而改变元素的css。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 js修改css的方法: 方法…

    2025年12月24日
    000
  • js如何改变css样式

    js改变css样式的方法:1、使用cssText方法;2、使用【setProperty()】方法;3、使用css属性对应的style属性。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 js改变css样式的方法: 第一种:用cssText div.style.cssText…

    2025年12月24日
    000
  • 为什么css放上面js放下面

    css放上面js放下面的原因:1、在加载html生成DOM tree的时候,可以同时对DOM tree进行渲染,这样可以防止闪跳,白屏或者布局混乱;2、javascript加载后会立即执行,同时会阻塞后面的资源加载。 本文操作环境:Windows7系统、HTML5&&CSS3版,DE…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信