当前位置: 首页 > article >正文

Go语言使用阿里云模版短信服务

在当今的互联网项目中,短信验证码、通知等功能已成为标配。本文将详细介绍如何使用Go语言集成阿里云短信服务(DYSMSAPI)实现短信发送功能。

一、准备工作

在开始之前,您需要完成以下准备工作:

  1. 注册阿里云账号并实名认证
  2. 开通短信服务(SMS)
  3. 申请短信签名和短信模板
  4. 获取AccessKey ID和AccessKey Secret

二、项目配置

首先创建一个新的Go项目,并添加阿里云SDK依赖:

go get github.com/aliyun/alibaba-cloud-sdk-go

三、代码实现

以下是完整的短信发送实现代码:

package mainimport ("fmt""github.com/aliyun/alibaba-cloud-sdk-go/services/dysmsapi""os"
)func main() {// 配置阿里云AccessKeyaccessKeyId := "LTAI5tNjR26666666NTi5"             // 替换为你的AccessKey IDaccessKeySecret := "2mFhAx4H666666661bMUyLxziCCqW" // 替换为你的AccessKey Secret// 创建客户端client, err := dysmsapi.NewClientWithAccessKey("cn-hangzhou", accessKeyId, accessKeySecret)if err != nil {fmt.Println("创建客户端失败:", err)os.Exit(1)}// 创建请求对象request := dysmsapi.CreateSendSmsRequest()request.Scheme = "https" // 使用HTTPS协议// 设置请求参数request.PhoneNumbers = "13467516788"      // 接收短信的手机号码request.SignName = "湖南XXXXXX有限公司"     // 短信签名名称request.TemplateCode = "SMS_275040510"    // 短信模板IDrequest.TemplateParam = `{"code":"1234"}` // 短信模板变量对应的实际值,JSON格式// 发送短信response, err := client.SendSms(request)if err != nil {fmt.Println("发送短信失败:", err)os.Exit(1)}// 处理响应fmt.Printf("响应状态: %s\n", response.Code)fmt.Printf("响应消息: %s\n", response.Message)fmt.Printf("业务ID: %s\n", response.BizId)fmt.Printf("请求ID: %s\n", response.RequestId)
}

四、代码解析

1. 客户端初始化

client, err := dysmsapi.NewClientWithAccessKey("cn-hangzhou", accessKeyId, accessKeySecret)

这里我们创建了一个阿里云短信服务的客户端,需要传入:

  • 区域ID(如cn-hangzhou)
  • AccessKey ID
  • AccessKey Secret

2. 请求参数设置

request := dysmsapi.CreateSendSmsRequest()
request.Scheme = "https" // 使用HTTPS协议
request.PhoneNumbers = "13467516757"
request.SignName = "湖南XXXXXX有限公司"
request.TemplateCode = "SMS_275040510"
request.TemplateParam = `{"code":"1234"}`

关键参数说明:

  • PhoneNumbers: 接收短信的手机号,多个号码用逗号分隔
  • SignName: 短信签名,需要在阿里云控制台申请并通过审核
  • TemplateCode: 短信模板ID,需要在控制台申请
  • TemplateParam: 模板变量,JSON格式

3. 发送请求与处理响应

response, err := client.SendSms(request)

发送请求后会返回响应对象,包含:

  • Code: 请求状态码,OK表示成功
  • Message: 状态码的描述
  • BizId: 发送回执ID,可用于查询发送状态
  • RequestId: 请求ID

五、常见问题

  1. 签名审核不通过:确保签名与营业执照名称一致
  2. 模板审核不通过:验证码模板必须包含"验证码"字样
  3. 错误码查询:参考阿里云官方文档中的错误码表

七、总结

通过阿里云SDK,我们可以轻松地在Go应用中集成短信发送功能。关键点包括:

  • 正确配置AccessKey
  • 使用审核通过的签名和模板
  • 正确处理响应和错误

希望本文能帮助你快速实现短信功能。如果有任何问题,欢迎在评论区留言讨论。

提示:在实际生产环境中,请妥善保管您的AccessKey,避免泄露造成安全风险。

http://www.lryc.cn/news/2394776.html

相关文章:

  • Leetcode 3231. 要删除的递增子序列的最小数量
  • 4.2.5 Spark SQL 分区自动推断
  • 基于昇腾MindSpeed训练加速库玩转智谱GLM-4-0414模型
  • 【图像处理入门】2. Python中OpenCV与Matplotlib的图像操作指南
  • Spring Boot微服务架构(九):设计哲学是什么?
  • GRCh38版本染色体位置转换GRCh37(hg19)
  • TC/BC/OC P2P/E2E有啥区别?-PTP协议基础概念介绍
  • 解决微信小程序中 Flex 布局下 margin-right 不生效的问题
  • Kafka数据怎么保障不丢失
  • 使用HTTPS进行传输加密
  • AI书签管理工具开发全记录(八):Ai创建书签功能实现
  • X-plore v4.43.05 强大的安卓文件管理器-MOD解锁高级版 手机平板/电视TV通用
  • 使用多Agent进行海报生成的技术方案及评估套件-P2P、paper2poster
  • Redis--缓存工具封装
  • python:在 PyMOL 中如何查看和使用内置示例文件?
  • SpringCloud——Docker
  • 机器学习:欠拟合、过拟合、正则化
  • 运用集合知识做斗地主案例
  • 《HelloGitHub》第 110 期
  • 使用 Shell 脚本实现 Spring Boot 项目自动化部署到 Docker(Ubuntu 服务器)
  • day023-网络基础与OSI七层模型
  • SpringAI系列4: Tool Calling 工具调用 【感觉这版本有bug】
  • 机器人--里程计
  • 设计模式——原型设计模式(创建型)
  • react库:class-variance-authority
  • 通过mqtt 点灯
  • 随笔笔记记录5.28
  • 大数据-273 Spark MLib - 基础介绍 机器学习算法 决策树 分类原则 分类原理 基尼系数 熵
  • 基于 Spring Boot + Vue 的墙绘产品展示交易平台设计与实现【含源码+文档】
  • 【机器学习】支持向量机