📲 一款满足你的多种发送需求的短信发送组件
- 支持目前市面多家服务商
- 一套写法兼容所有平台
- 简单配置即可灵活增减服务商
- 内置多种服务商轮询策略、支持自定义轮询策略
- 统一的返回值格式,便于日志与监控
- 更多等你去发现与改进...
- Golang >= 1.18
$ go get github.com/pkg6/go-sms
package main
import (
gosms "github.com/pkg6/go-sms"
"github.com/pkg6/go-sms/gateways"
"github.com/pkg6/go-sms/gateways/twilio"
)
func main() {
sms := gosms.NewParser(gateways.Gateways{Twilio: twilio.Twilio{AccountSID: "ACd********", AuthToken: "***********", TwilioPhoneNumber: "+1********"}})
// 常规
sms.Send(18888888888, gosms.MapStringAny{
"content": "您的验证码是:****。请不要把验证码泄露给其他人。",
"template": "SMS_001",
"data": gosms.MapStrings{
"code": "6379",
},
}, nil)
}
由于使用多网关发送,所以一条短信要支持多平台发送,每家的发送方式不一样,但是我们抽象定义了以下公用属性:
content
文字内容,使用在像云片类似的以文字内容发送的平台sign_name
签名template
模板 ID,使用在以模板ID来发送短信的平台data
模板变量,使用在以模板ID来发送短信的平台
所以,在使用过程中你可以根据所要使用的平台定义发送的内容。
sms.Send(18888888888, gosms.MapStringAny{
"content": "您的验证码是:****。请不要把验证码泄露给其他人。",
"template": "SMS_001",
"data": gosms.MapStrings{
"code": "6379",
},
}, nil)
你也可以使用闭包来返回对应的值:
sms.Send(18888888888, gosms.MapStringAny{
"content": func(gateway gosms.IGateway) string {
return "您的验证码是:****。请不要把验证码泄露给其他人。"
},
"template": func(gateway gosms.IGateway) string {
if gateway.GetName() == "aliyun" {
return "TP2818"
}
return "SMS_001"
},
"data": func(gateway gosms.IGateway) gosms.MapStrings {
return map[string]string{
"code": "1234",
}
},
}, nil)
默认使用初始化中的网关发送,如果某一条短信你想要覆盖默认的设置。在 send
方法中使用第三个参数即可:
sms := gosms.NewGateways(twilio.GateWay("ACd********", "***********", "+1***********"))
sms.Send(18888888888, gosms.MapStringAny{
"content": "您的验证码是:****。请不要把验证码泄露给其他人。",
}, nil)
本拓展已经支持用户自定义网关,你可以很方便的配置即可当成与其它拓展一样的使用:
sms := gosms.NewGateways()
sms.Extend("aliyun", aliyun.GateWay("accessKeyId", "accessKeySecret"))
sms.Send(18888888888, gosms.MapStringAny{
"content": "您的验证码是:****。请不要把验证码泄露给其他人。",
}, []string{"aliyun"})
自定义网关实现接口
// IGateway 网关
type IGateway interface {
// I 用于初始化默认值
I() IGateway
// GetName 网关名称
GetName() string
// Send 发送操作
Send(to IPhoneNumber, message IMessage) (SMSResult, error)
}
package main
import (
"fmt"
gosms "github.com/pkg6/go-sms"
"github.com/pkg6/go-sms/gateways/twilio"
)
func main() {
gateway := twilio.GateWay("ACd********", "********", "+1111111")
var message = gosms.MessageContent("Hello from Twilio")
number := gosms.CHNPhoneNumber(18888888888)
result, err := gosms.Sender(number, message, gateway)
if resp, ok := result.ClientResult.Response.(twilio.Response); ok {
fmt.Println(resp)
}
fmt.Println(err)
}
如果你认可我们的开源项目,有兴趣为 go-sms的发展做贡献,竭诚欢迎加入我们一起开发完善。无论是报告错误或是 Pull Request 开发,那怕是修改一个错别字也是对我们莫大的帮助。