Kako poslati više SMS poruka iz Go-a
Najjednostavniji način za slanje više SMS poruka iz Go-a je korištenje ugrađenog HTTP/Rest SMS API-ja Ozeki SMS Gatewaya. Kada koristite ovaj API, slat ćete SMS poruke slanjem HTTP Post zahtjeva SMS gatewayu. HTTP Post zahtjev će sadržavati poruku formatiranu u json formatu. SMS gateway će poslati ovaj SMS na telefon primatelja i vratit će HTTP 200 OK odgovor na vaš zahtjev.
Go kod za slanje više SMS poruka na mobilni telefon
Go SMS primjer koda ispod pokazuje kako možete poslati više SMS poruka koristeći http rest SMS API Ozeki SMS Gatewaya koristeći Go paket github.com/ozekisms/go_send_sms_http_rest_ozeki. Ovaj paket vam je dostupan besplatno i možete ga koristiti i mijenjati u bilo kojem od vaših projekata.
SendMultipleSms.gopackage main import ( "fmt" ozeki "github.com/ozekisms/go_send_sms_http_rest_ozeki" ) func main() { configuration := ozeki.NewConfiguration( "http_user", "qwe123", "http://127.0.0.1:9509/api", ) msg1 := ozeki.NewMessage() msg1.ToAddress = "+36201111111" msg1.Text = "Hello world 1" msg2 := ozeki.NewMessage() msg2.ToAddress = "+36202222222" msg2.Text = "Hello world 2" msg3 := ozeki.NewMessage() msg3.ToAddress = "+36203333333" msg3.Text = "Hello world 3" api := ozeki.NewMessageApi(configuration) result := api.Send([]ozeki.Message{msg1, msg2, msg3}) fmt.Println(result) }
Kako koristiti Go SMS primjer:
Ovaj Go SMS primjer može se koristiti u bilo kojoj Go aplikaciji. Da biste ga koristili, morate preuzeti paket github.com/ozekisms/go_send_sms_http_rest_ozeki. Nakon što je paket preuzet, potrebno je dodati referencu na njega u vaš Go izvorni kod. To će vam omogućiti korištenje klasa koje pruža paket github.com/ozekisms/go_send_sms_http_rest_ozeki. Možete koristiti klasu Message za kreiranje SMS-a. Možete koristiti klasu MessageApi za slanje SMS-a SMS gatewayu. SMS gateway će proslijediti vašu poruku mobilnoj mreži bilo putem bežične veze ili putem interneta.
Preuzmite SendMultipleSms.go
Izvorni kod objašnjen u ovom članku može se preuzeti, koristiti i mijenjati besplatno.
Preuzmi: SendMultipleSms.go.zip (1.08Kb)
Što se nalazi u SendMultipleSms.go.zip datoteci?
U SendMultipleSms.go.zip pronaći ćete datoteku SendSms.go, koja sadrži primjer koda koji vam pokazuje kako poslati SMS. Ovaj primjer koda je naveden ispod.
Kako poslati SMS iz Go-a (Jednostavne smjernice)
Za slanje SMS-a iz Go-a:
- Instalirajte HTTP API korisnika
- Omogućite bilježenje komunikacijskih događaja na kartici Napredno
- Postavite Visual Studio
- Preuzmite i raspakirajte datoteku SendMultipleSms.go.zip
- Pokrenite Ozeki SMS Gateway aplikaciju
- Pokrenite SendMultipleSms.go Go kod koristeći naredbeni redak
- Provjerite zapisnike da vidite je li SMS poslan
Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika
Da biste mogli poslati više SMS poruka iz Go-a, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu gdje razvijate svoj Go kod u bilo kojem tekstualnom editoru, kao što je Windows notepad. Nakon instalacije, sljedeći korak je povezivanje Ozeki SMS Gatewaya s mobilnom mrežom. Možete poslati testni SMS iz Ozeki GUI-ja kako biste potvrdili da vaša mobilna mrežna veza radi. Konačni korak za pripremu vašeg okruženja je kreiranje HTTP SMS API korisničkog računa. Kreirajte korisnika s korisničkim imenom "http_user" i lozinkom "qwe123" kako bi primjer radio bez izmjena.
Nakon što je okruženje postavljeno, možete pokrenuti svoj Go kod.
HTTP API URL za slanje više SMS poruka iz Go-a
Da biste poslali SMS iz Go-a, vaš Go će morati poslati HTTP zahtjev SMS gatewayu. API URL je prikazan ispod. Imajte na umu da IP adresa (127.0.0.1) treba biti zamijenjena IP adresom vašeg SMS gatewaya. Ako je Ozeki SMS Gateway instaliran na istom računalu gdje se pokreće Go SMS aplikacija, ovo može biti 127.0.0.1. Ako je instaliran na drugom računalu, treba biti IP adresa tog računala.
http://127.0.0.1:9509/api?action=rest
HTTP autentifikacija za slanje SMS-a iz Go-a
Da biste autentificirali Go SMS klijenta, morate poslati korisničko ime i lozinku u base64 kodiranom stringu na poslužitelj u HTTP zahtjevu. Korišteni format je: base64(korisničko_ime+":"+lozinka). U Go-u možete koristiti sljedeći kod za ovo kodiranje:
import b64 "encoding/base64" func (api *MessageApi) createAuthorizationHeader(username string, password string) string { var usernamePassword string = username + ":" + password var usernamePasswordEncoded string = b64.StdEncoding.EncodeToString([]byte(usernamePassword)) return "Basic " + usernamePasswordEncoded }
Na primjer, ako kodirate korisničko ime 'http_user' i lozinku 'qwe123', dobit ćete sljedeći base64 kodirani string: aHR0cF91c2VyOnF3ZTEyMw==. Za slanje
HTTP zaglavlje zahtjeva za slanje SMS-a iz Go-aZa slanje SMS poruka potrebno je uključiti sljedeće retke kao zaglavlja u HTTP zahtjev. Imajte na umu da uključujemo vrstu sadržaja i zaglavlje za autorizaciju.
Content-Type: application/json Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
HTTP zahtjev za slanje SMS-a iz Go-a
Za slanje SMS-a, vaša Go aplikacija će poslati HTTP zahtjev sličan donjem primjeru. Imajte na umu da ovaj zahtjev sadrži dio HTTP zaglavlja i dio HTTP tijela. HTTP tijelo je JSON kodirani niz podataka. Sadrži brojeve primatelja i tekstove poruka.
POST /api?action=sendmsg HTTP/1.1 Content-Length: 1277 Content-Type: application/json Accept-Encoding: gzip Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw== Host: 127.0.0.1:9509 User-Agent: Go-http-client/1.1 { "messages": [ { "message_id": "6e5384bb-e07b-11eb-a3b4-74d4355e997d", "from_connection": "", "from_address": "", "from_station": "", "to_connection": "", "to_address": "+36201111111", "to_station": "", "text": "Pozdrav svijete 1", "create_date": "2021-07-09T08:03:50", "valid_until": "2021-07-16T08:03:50", "time_to_send": "2021-07-09T08:03:50", "submit_report_requested": true, "view_report_requested": true, "delivery_report_requested": true, "tags": [], "status": "" }, { "message_id": "6e622a28-e07b-11eb-a3b4-74d4355e997d", "from_connection": "", "from_address": "", "from_station": "", "to_connection": "", "to_address": "+36202222222", "to_station": "", "text": "Pozdrav svijete 2", "create_date": "2021-07-09T08:03:50", "valid_until": "2021-07-16T08:03:50", "time_to_send": "2021-07-09T08:03:50", "submit_report_requested": true, "view_report_requested": true, "delivery_report_requested": true, "tags": [], "status": "" }, { "message_id": "6e622a28-e07b-11eb-a3b5-74d4355e997d", "from_connection": "", "from_address": "", "from_station": "", "to_connection": "", "to_address": "+36203333333", "to_station": "", "text": "Pozdrav svijete 3", "create_date": "2021-07-09T08:03:50", "valid_until": "2021-07-16T08:03:50", "time_to_send": "2021-07-09T08:03:50", "submit_report_requested": true, "view_report_requested": true, "delivery_report_requested": true, "tags": [], "status": "" } ] }
HTTP odgovor primljen od Go SMS primjera
Nakon što SMS gateway primi ovaj zahtjev, generirat će HTTP odgovor. HTTP odgovor će sadržavati statusni kod kako bi naznačio je li zahtjev za slanje SMS-a bio uspješan ili ne. Također će vratiti JSON kodiranu strukturu kako bi vam pružio korisne pojedinosti o slanju poruke.
HTTP/1.1 200 OK User-Agent: OZEKI 10.3.123 (www.myozeki.com) Content-Type: application/json; charset=utf8 Last-Modified: Fri, 09 Jul 2021 07:59:56 GMT Server: 10/10.3.123 Transfer-Encoding: chunked { "http_code": 200, "response_code": "SUCCESS", "response_msg": "Poruke su u redu za isporuku.", "data": { "total_count": 3, "success_count": 3, "failed_count": 0, "messages": [ { "message_id": "6e5384bb-e07b-11eb-a3b4-74d4355e997d", "from_station": "%", "to_address": "+36201111111", "to_station": "%", "text": "Pozdrav svijete 1", "create_date": "2021-07-09 08:03:50", "valid_until": "2021-07-16 08:03:50", "time_to_send": "2021-07-09 08:03:50", "submit_report_requested": true, "delivery_report_requested": true, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" }, { "message_id": "6e622a28-e07b-11eb-a3b4-74d4355e997d", "from_station": "%", "to_address": "+36202222222", "to_station": "%", "text": "Pozdrav svijete 2", "create_date": "2021-07-09 08:03:50", "valid_until": "2021-07-16 08:03:50", "time_to_send": "2021-07-09 08:03:50", "submit_report_requested": true, "delivery_report_requested": true, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" }, { "message_id": "6e622a28-e07b-11eb-a3b5-74d4355e997d", "from_station": "%", "to_address": "+36203333333", "to_station": "%", "text": "Pozdrav svijete 3", "create_date": "2021-07-09 08:03:50", "valid_until": "2021-07-16 08:03:50", "time_to_send": "2021-07-09 08:03:50", "submit_report_requested": true, "delivery_report_requested": true, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" } ] } }
Kako poslati više SMS poruka iz Go-a koristeći Go SMS API (Video tutorial)
Ovaj video vam pokazuje kako preuzeti datoteku SendMultipleSms.go.zip s ove stranice. Ako pogledate video, primijetit ćete da se sadržaj SendMultipleSms.go.zip datoteke postavlja na Windows radnu površinu. Također ćete vidjeti da pokrećemo naredbeni redak kako bismo poslali SMS.
Go SMS primjer: SendMultipleSms.go
Primjer koda u nastavku dio je datoteke SendMultipleSms.go.
Nakon što je SMS poslan, dobro je provjeriti svoj SMS pristupnik, kako biste vidjeli što je primio. Dnevnik možete provjeriti otvaranjem detalja HTTP korisnika iz upravljačke konzole Ozeki SMS pristupnika. Sljedeći video pokazuje što trebate tražiti.
Sažetak
Ovaj vodič je trebao objasniti slanje više SMS poruka u Go uz pomoć Ozeki SMS pristupnika. S ovim rješenjem, kontaktiranje više korisnika odjednom je brzo i jednostavno. Korištenjem ove tehnologije može se uštedjeti puno vremena i energije jer slanje više SMS poruka znatno olakšava posao. Ozeki SMS pristupnik radi s visokom performansom, što znači da može poslati do 1000 SMS poruka u sekundi.
Svakako nastavite čitati na Ozeki-ovoj stranici s tutorijalima, gdje možete pronaći više informacija o temama kao što su brisanje SMS poruka u Go-u.
Jedino što sada preostaje je preuzeti Ozeki SMS pristupnik i započeti s radom!
More information
- Go pošalji SMS s HTTP REST API-jem (primjer koda)
- Go pošalji više SMS-ova s HTTP REST API-jem (primjer koda)
- Go zakazani SMS s HTTP REST API-jem (primjer koda)
- Go primi SMS s HTTP REST API-jem (primjer koda)
- Go obriši SMS s HTTP REST API-jem (primjer koda)
- Kako preuzeti najnoviju Go SMS biblioteku s Githuba