api - SendGrid 电子邮件活动 API 没有结果
问题描述
我正在使用此文档尝试从 SendGrid 电子邮件活动 API 接收退回信息:
但它没有返回任何结果,尽管我们的仪表板上显示了大约 50 次反弹(可从 SendGrid Web 界面的“活动”部分查看)。
要求:
curl --request GET \
--url 'https://api.sendgrid.com/v3/messages?limit=100&query=status%3D%22bounced%22' \
--header 'authorization: Bearer <<TOKEN_REMOVED>>'
回复:
{"messages":[]}
显然 <<TOKEN_REMOVED>> 是我运行它时的实际令牌:)
注意 -当我使用v3/suppression/bounces
端点返回它工作正常的所有内容时(响应大量的退回 JSON),但是我希望能够使用更灵活的messages
端点来查询特定的电子邮件等。
curl --request GET \
--url https://api.sendgrid.com/v3/suppression/bounces \
--header 'accept: application/json' \
--header 'authorization: Bearer <<TOKEN_REMOVED>>' \
--header 'content-type: application/json' \
--data '{}' \
解决方案
有两个地方记录了消息 API 的使用:
但是关于status
查询参数,“入门”指南有过时的示例,其中错误地包括&query=status%3D%22bounced%22'
.
在查询参考中明确提到status
只能是以下之一:
有效值包括“delivered”、“not_delivered”和“processing”
然而,由于 sendgrid 还依赖其自己的/messages
API 来检索 GUI 中的值,因此检查流量显示它使用type
查询参数来识别退回(见下图)。
免责声明:此type
参数似乎没有记录在案,因此使用它需要您自担风险。
进一步阅读:如果您想在不定期轮询端点的情况下以被动方式获知失败的电子邮件事件/messages
,您应该查看 sendgrid 的webhook 机制,它将调用您选择的端点,以便向您提供有关电子邮件状态的信息,包括它是否反弹。
推荐阅读
- javascript - 在 Jest 中运行测试用例时出现错误`TypeError: debug is not a function`
- python - 将月份的天+周转换为日期
- html - 当 min 和 max 具有相同年份时,如何防止在日期输入中自动插入年份?
- python - 向 django Q() 发送键、值
- api - 空手道:如何在响应中检查属性值是否为空
- matplotlib - 如何确定 matplotlib 文本艺术家是否与轴边界重叠?
- angular - 在角度测试用例中模拟 document.querySelectorAll()
- java - 小于N的最大连续合数序列
- sqlite - sqlite3如何选择与另一个列名匹配的列的值
- python - Python Pandas,计算 CSV 中某个项目的所有出现次数,并将该计数分配给该项目的唯一名称