AWS Pinpoint介绍
Amazon Pinpoint 为营销人员和开发人员提供了一款可自定义的工具,助力他们大规模地开展跨渠道、行业和活动的客户通信。


Amazon Pinpoint是一个全面的客户参与平台,旨在帮助营销人员和开发人员大规模地开展跨渠道、行业和活动的客户通信。它提供了一系列功能,包括创建和管理营销活动、客户细分、推送通知、电子邮件、短信、语音消息以及应用程序内消息等,通过这些功能,用户可以与客户进行互动并分析活动效果,以优化营销策略。
使用Amazon Pinpoint的主要步骤包括:
- 创建项目:首先,用户需要在AWS控制台中创建一个新的项目,这是使用Amazon Pinpoint的第一步。
- 导入数据并创建客户细分:接下来,导入客户数据并创建不同的客户细分,以便更精确地定位目标受众。
- 创建活动:设计并创建各种营销活动,包括推送通知、电子邮件、短信等。
- 查看活动分析:活动创建后,可以通过分析工具查看活动的效果,包括送达率、打开率、点击率等,以便优化未来的活动。
- 项目管理和发送:管理项目,包括设置推送通知、电子邮件、短信等,并监控其性能。
Amazon Pinpoint还提供了多种最佳实践和建议,帮助用户优化送达率、提高客户参与度,并通过收件箱置入测试等方式确保邮件不被标记为垃圾邮件。此外,它还支持使用专用IP地址,帮助用户更好地管理邮件发送,以及通过沙盒模式对短信和语音消息进行限制和管理。
总的来说,Amazon Pinpoint是一个功能强大的工具,它允许用户通过多种渠道与客户进行互动,并通过详细的数据分析和优化建议,提高营销活动的效率和效果12。
Amazon Pinpoint 的安全最佳实践
使用 AWS 身份和访问管理 (IAM) 账户控制 API 操作的 Amazon Pinpoint 访问权限,尤其是创建、修改或 Amazon Pinpoint 删除资源的操作。对于 Amazon Pinpoint API,此类资源包括项目、活动和旅程。对于 Amazon Pinpoint SMS 和 Voice API,此类资源包括电话号码、资源池和配置集。
为每个管理 Amazon Pinpoint 资源的人创建一个单独的用户,包括你自己。请勿使用 AWS 根凭证来管理 Amazon Pinpoint 资源。
授予每位用户执行其职责所需的最低权限集。
使用 IAM 组有效地管理适用于多个用户的权限。
定期轮换您的 IAM 凭证。
发送短信或语音消息的示例
您可以参照以下代码示例,使用 AWS SDK for Python (Boto3)发送短信。
import boto3
from botocore.exceptions import ClientError
def send_sms_message(sms_voice_v2_client, configuration_set, context_keys,
country_parameters, destination_number, dry_run, keyword,
max_price, message_body, message_type, origination_number,
ttl):
try:
response = sms_voice_v2_client.send_text_message(
ConfigurationSetName=configuration_set,
Context=context_keys,
DestinationCountryParameters=country_parameters,
DestinationPhoneNumber=destination_number,
DryRun=dry_run,
Keyword=keyword,
MaxPrice=max_price,
MessageBody=message_body,
MessageType=message_type,
OriginationIdentity=origination_number,
TimeToLive=ttl
)
except ClientError as e:
print(e.response)
else:
return response['MessageId']
def main():
configuration_set = "MyConfigurationSet"
context_keys = {"key1": "value1"}
country_parameters = {
"IN_TEMPLATE_ID": "TEMPLATE01234",
"IN_ENTITY_ID": "ENTITY98765"
}
destination_number = "+14255550168"
dry_run = False
keyword = "MyKeyword"
max_price = "2.00"
message_body = ("This is a test message sent from Amazon Pinpoint SMS "
"using the AWS SDK for Python (Boto3). ")
message_type = "TRANSACTIONAL"
origination_number = "+12065550183"
ttl = 120
print(
f"Sending text message to {destination_number}.")
message_id = send_sms_message(
boto3.client('pinpoint-sms-voice-v2'), configuration_set, context_keys,
country_parameters, destination_number, dry_run, keyword, max_price,
message_body, message_type, origination_number, ttl)
print(f"Message sent!\nMessage ID: {message_id}")
if __name__ == '__main__':
main()
在前面的示例中,对 main() 函数进行以下更改:
将
configuration_set的值改为您要用于发送此消息的配置集的名称或 Amazon 资源名称 (ARN)。将
context_keys的值改为您要在发送此消息时使用的键和值。这些键出现在与此消息关联的事件记录中。如果您使用已注册的发件人 ID 向印度的客户发送消息,请将
country_parameters的值改为匹配您在注册发件人 ID 时收到的注册实体 ID 和模板 ID。
重要
如果您不使用注册的发件人 ID 向印度的客户发送消息,请完全忽略此参数。同时,还必须删除
send_sms_message函数中的相应行。将
destination_number的值改为您要向其发送消息的电话号码。如果要在不发送任何消息的情况下执行此操作,请将
dry_run的值改为True。将
max_price的值改为您发送此消息的每个消息部分要花费的最大金额(以美元为单位)。一个消息部分最多包含 140 字节的信息。有关更多信息,请参阅 短信字符限制。更改
message_body的值以包括您要发送的消息。一条消息的最大长度取决于其所包含的字符。有关短信字符编码的更多信息,请参阅短信字符限制。更改
message_type的值以表示相应的消息类别。有效值包括 TRANSACTIONAT(适用于重要或对时间敏感的消息)和 PROMOTION(适用于不重要或对不时间敏感的消息)。将
origination_number的值改为您要用于发送消息的电话号码。电话号码必须使用 E.164 格式。将的值更改
ttl为 Amazon Pinpoint SMS 应尝试发送消息的时间(以秒为单位)。您可以将 TTL 值设置为最多 259200 秒(72 小时)。
发送语音消息
您可以使用以下代码示例,通过 AWS SDK for Python (Boto3)发送语音消息。
import boto3
from botocore.exceptions import ClientError
def send_voice_message(sms_voice_v2_client, configuration_set, context_keys,
destination_number, dry_run, max_price, message_body,
message_type, origination_number, ttl, voice_id):
try:
response = sms_voice_v2_client.send_voice_message(
ConfigurationSetName=configuration_set,
Context=context_keys,
DestinationPhoneNumber=destination_number,
DryRun=dry_run,
MaxPricePerMinute=max_price,
MessageBody=message_body,
MessageBodyTextType=message_type,
OriginationIdentity=origination_number,
TimeToLive=ttl,
VoiceId=voice_id
)
except ClientError as e:
print(e.response)
else:
return response['MessageId']
def main():
configuration_set = "MyConfigurationSet"
context_keys = {"key1":"value1"}
destination_number = "+12065550123"
dry_run = False
max_price = "2.00"
message_body = (
"<speak>"
"This is a test message sent from <emphasis>Amazon Pinpoint SMS</emphasis>"
"using the <break strength='weak'/> AWS SDK for Python (Boto3). "
"<amazon:effect phonation='soft'>Thank you for listening."
"</amazon:effect>"
"</speak>")
message_type = "SSML"
origination_number = "+18445550142"
ttl = 120
voice_id = "MATTHEW"
print(
f"Sending voice message with Amazon Pinpoint SMS from {origination_number} to {destination_number}.")
message_id = send_voice_message(
boto3.client('pinpoint-sms-voice-v2'), configuration_set, context_keys,
destination_number, dry_run, max_price, message_body, message_type,
origination_number, ttl, voice_id)
print(f"Message sent!\nMessage ID: {message_id}")
if __name__ == '__main__':
main()
在前面的示例中,对 main() 函数进行以下更改:
将
configuration_set的值改为您要用于发送此消息的配置集的名称或 Amazon 资源名称 (ARN)。将
context_keys的值改为您要在发送此消息时使用的键和值。这些键出现在与此消息关联的事件记录中。将
destination_number的值改为您要向其发送消息的电话号码。将
max_price的值改为发送此消息每分钟要花费的最大金额。更改
message_body的值以包括您要发送的消息。消息最多可包含 6,000 个字符。如果要使用纯文本脚本而不是 SSML 格式的脚本,请将
message_type的值改为TEXT将
origination_number的值改为您要用于发送消息的电话号码。电话号码必须使用 E.164 格式。如果要在不发送任何消息的情况下执行此操作,请将
dry_run的值改为True。将的值更改
ttl为 Amazon Pinpoint SMS 应尝试发送消息的时间(以秒为单位)。您可以将 TTL 值设置为最多 259200 秒(72 小时)。将
MATTHEW替换为要用于发送消息的 Amazon Polly 语音的名称。有关支持的语音的完整列表,请参阅《短信和语音》第 2 版 API 参考SendVoiceMessage中。如果您未指定语音,则您的消息将使用 “MATTHEW” 语音发送。