go語言實現(xiàn)短信發(fā)送實例探究
特點
- 支持目前市面多家服務(wù)商
- 一套寫法兼容所有平臺
- 簡單配置即可靈活增減服務(wù)商
- 內(nèi)置多種服務(wù)商輪詢策略、支持自定義輪詢策略
- 統(tǒng)一的返回值格式,便于日志與監(jiān)控
- 更多等你去發(fā)現(xiàn)與改進...
平臺支持
目前支持
- 阿里云
- 互億無線
- 短信寶
- 聚合數(shù)據(jù)
- 網(wǎng)易云信
- 微網(wǎng)通聯(lián)
- twilio
環(huán)境需求
- 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********"}}) // 常規(guī) sms.Send(18888888888, gosms.MapStringAny{ "content": "您的驗證碼是:****。請不要把驗證碼泄露給其他人。", "template": "SMS_001", "data": gosms.MapStrings{ "code": "6379", }, }, nil) }
短信內(nèi)容
由于使用多網(wǎng)關(guān)發(fā)送,所以一條短信要支持多平臺發(fā)送,每家的發(fā)送方式不一樣,但是我們抽象定義了以下公用屬性:
content
文字內(nèi)容,使用在像云片類似的以文字內(nèi)容發(fā)送的平臺sign_name
簽名template
模板 ID,使用在以模板ID來發(fā)送短信的平臺data
模板變量,使用在以模板ID來發(fā)送短信的平臺
所以,在使用過程中你可以根據(jù)所要使用的平臺定義發(fā)送的內(nèi)容。
sms.Send(18888888888, gosms.MapStringAny{ "content": "您的驗證碼是:****。請不要把驗證碼泄露給其他人。", "template": "SMS_001", "data": gosms.MapStrings{ "code": "6379", }, }, nil)
你也可以使用閉包來返回對應(yīng)的值:
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)
發(fā)送網(wǎng)關(guān)
默認(rèn)使用初始化中的網(wǎng)關(guān)發(fā)送,如果某一條短信你想要覆蓋默認(rèn)的設(shè)置。在 send
方法中使用第三個參數(shù)即可:
sms := gosms.NewGateways(twilio.GateWay("ACd********", "***********", "+1***********")) sms.Send(18888888888, gosms.MapStringAny{ "content": "您的驗證碼是:****。請不要把驗證碼泄露給其他人。", }, nil)
自定義網(wǎng)關(guān)
本拓展已經(jīng)支持用戶自定義網(wǎng)關(guān),你可以很方便的配置即可當(dāng)成與其它拓展一樣的使用:
sms := gosms.NewGateways() sms.Extend("aliyun", aliyun.GateWay("accessKeyId", "accessKeySecret")) sms.Send(18888888888, gosms.MapStringAny{ "content": "您的驗證碼是:****。請不要把驗證碼泄露給其他人。", }, []string{"aliyun"})
自定義網(wǎng)關(guān)實現(xiàn)接口
// IGateway 網(wǎng)關(guān) type IGateway interface { // I 用于初始化默認(rèn)值 I() IGateway // GetName 網(wǎng)關(guān)名稱 GetName() string // Send 發(fā)送操作 Send(to IPhoneNumber, message IMessage) (SMSResult, error) }
通過Sender函數(shù)去發(fā)送
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) }
總結(jié)
以上就是go語言實現(xiàn)短信發(fā)送實例探究的詳細(xì)內(nèi)容,更多關(guān)于go語言發(fā)送短信的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解Golang中string的實現(xiàn)原理與高效使用
在Go語言中,無論是字符串常量、字符串變量還是代碼中出現(xiàn)的字符串字面量,它們的類型都被統(tǒng)一設(shè)置為string,下面就跟隨小編一起來了解一下Golang中string的實現(xiàn)原理與高效使用吧2024-01-01golang如何使用struct的tag屬性的詳細(xì)介紹
這篇文章主要介紹了golang如何使用struct的tag屬性的詳細(xì)介紹,從例子說起,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11詳解Golang中errors包如何返回自定義error類型
這篇文章主要為大家詳細(xì)介紹了Golang中errors包如何返回自定義error類型,文中的示例代碼簡潔易懂,有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-09-09go gin中間件關(guān)于 c.next()、c.abort()和return的使用小結(jié)
中間件的執(zhí)行順序是按照注冊順序執(zhí)行的,中間件可以通過 c.abort() + retrurn 來中止當(dāng)前中間件,后續(xù)中間件和處理器的處理流程,?這篇文章給大家介紹go gin中間件關(guān)于 c.next()、c.abort()和return的使用小結(jié),感興趣的朋友跟隨小編一起看看吧2024-03-03