Kako poslati više SMS poruka iz R-a
Najjednostavniji način za slanje više SMS poruka iz R-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 ovu SMS poruku na telefon primatelja i vratit će HTTP 200 OK odgovor na vaš zahtjev.
R kod za slanje više SMS poruka na mobilni telefon
Primjer R SMS koda ispod pokazuje kako možete poslati SMS koristeći HTTP REST SMS API Ozeki SMS Gatewaya s Ozeki.Libs.Rest bibliotekom. Ova biblioteka vam je dostupna besplatno i možete je koristiti i mijenjati u bilo kojem od vaših projekata.
SendMultipleSms.Rlibrary(Ozeki.Libs.Rest) configuration <- Ozeki.Libs.Rest::Configuration$new( username = "http_user", password = "qwe123", api_url = "http://127.0.0.1:9509/api" ) msg1 <- Ozeki.Libs.Rest::Message$new() msg1$to_address <- "+36201111111" msg1$text <- "Hello world 1" msg2 <- Ozeki.Libs.Rest::Message$new() msg2$to_address <- "+36202222222" msg2$text <- "Hello world 2" msg3 <- Ozeki.Libs.Rest::Message$new() msg3$to_address <- "+36203333333" msg3$text <- "Hello world 3" api <- Ozeki.Libs.Rest::MessageApi$new(configuration) result <- api$send(list(msg1, msg2, msg3)) print(result$to_string())
Kako koristiti R SMS primjer:
Ovaj R SMS primjer može se koristiti u bilo kojoj R aplikaciji. Da biste ga koristili, morate preuzeti Ozeki.Libs.Rest biblioteku. Nakon što se biblioteka preuzme, trebate dodati referencu na nju u svoj R izvorni kod. To će vam omogućiti korištenje klasa koje pruža Ozeki.Libs.Rest biblioteka. Možete koristiti klasu Message za kreiranje SMS poruke. Možete koristiti klasu MessageApi za slanje SMS-a SMS gatewayu. SMS gateway će proslijediti vašu poruku mobilnoj mreži putem bežične veze ili putem interneta.
Preuzmite SendMultipleSms.R
Izvorni kod objašnjen u ovom članku može se besplatno preuzeti, koristiti i mijenjati.
Preuzmi: SendMultipleSms.R.zip (407B)
Što se nalazi u SendMultipleSms.R.zip datoteci?
U SendMultipleSms.R.zip pronaći ćete datoteku SendMultipleSms.R, koja sadrži primjer koda koji vam pokazuje kako poslati SMS. Ovaj primjer koda je naveden ispod.
Kako poslati SMS iz R-a (Jednostavne upute)
Za slanje SMS-a iz R-a:
- Instalirajte HTTP API korisnika
- Omogućite bilježenje komunikacijskih događaja na kartici Napredno
- Postavite Visual Studio
- Preuzmite i raspakirajte datoteku SendMultipleSms.R.zip
- Pokrenite Ozeki SMS Gateway aplikaciju
- Pokrenite SendMultipleSms.R R kod koristeći naredbeni redak
- Provjerite zapisnike kako biste vidjeli je li SMS poslan
Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika
Da biste mogli slati SMS iz R-a, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu na kojem razvijate svoj R kod u bilo kojem uređivaču teksta, 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 R kod.
HTTP API URL za slanje SMS-a iz R-a
Da biste poslali SMS iz R-a, vaš R ć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 na kojem se pokreće R 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 R-a
Da biste autentificirali R SMS klijent, 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 R-u možete koristiti sljedeći kod za ovo kodiranje:
username_password <- paste(username, ":", password, sep="") username_password_encoded <- base64enc::base64encode(charToRaw(username_password)) return (paste("Basic", username_password_encoded, sep=" "))
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 R-a
Da biste poslali SMS poruke, morate uključiti sljedeće retke kao zaglavlja u HTTP zahtjevu. Imajte na umu da uključujemo Content-Type i Authorization zaglavlje.
Content-Type: application/json Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Za slanje SMS-a, vaša R aplikacija će poslati HTTP zahtjev sličan onome u nastavku. 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 koje šaljemo.
POST /api?action=sendmsg HTTP/1.1 Content-Length: 962 Content-Type: application/json Accept: application/json Accept-Encoding: deflate, gzip Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw== Host: 127.0.0.1:9509 User-Agent: libcurl/7.64.1 r-curl/4.3.2 httr/1.4.2 { "messages": [ { "message_id": "fcb65595-06bd-41fe-84e5-f3f8912ff0a1", "to_address": "+36201111111", "text": "Hello world 1", "create_date": "2021-07-13T12:46:23", "valid_until": "2021-07-20T12:46:23", "time_to_send": "2021-07-13T12:46:23", "is_submit_report_requested": true, "is_delivery_report_requested": true, "is_view_report_requested": true }, { "message_id": "e14c1980-ca12-4d83-92f3-b25ebf6e1b97", "to_address": "+36202222222", "text":"Hello world 2", "create_date": "2021-07-13T12:46:23", "valid_until": "2021-07-20T12:46:23", "time_to_send": "2021-07-13T12:46:23", "is_submit_report_requested": true, "is_delivery_report_requested": true, "is_view_report_requested": true }, { "message_id": "5f7f0290-172a-446e-a9fe-cf6b22c84fe6", "to_address": "+36203333333", "text": "Hello world 3", "create_date": "2021-07-13T12:46:23", "valid_until": "2021-07-20T12:46:23", "time_to_send": "2021-07-13T12:46:23", "is_submit_report_requested": true, "is_delivery_report_requested": true, "is_view_report_requested": true } ] }
HTTP odgovor primljen u R SMS primjeru
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 detalje o slanju poruka.
HTTP/1.1 200 OK User-Agent: OZEKI 10.3.123 (www.myozeki.com) Content-Type: application/json; charset=utf8 Last-Modified: Tue, 13 Jul 2021 14:08:09 GMT Server: 10/10.3.123 Transfer-Encoding: chunked { "http_code": 200, "response_code": "SUCCESS", "response_msg": "Poruke su u redu čekanja za isporuku.", "data": { "total_count": 3, "success_count": 3, "failed_count": 0, "messages": [ { "message_id": "fcb65595-06bd-41fe-84e5-f3f8912ff0a1", "from_station": "%", "to_address": "+36201111111", "to_station": "%", "text": "Hello world 1", "create_date": "2021-07-13 12:46:23", "valid_until": "2021-07-20 12:46:23", "time_to_send": "2021-07-13 12:46:23", "submit_report_requested": true, "delivery_report_requested": false, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" }, { "message_id": "e14c1980-ca12-4d83-92f3-b25ebf6e1b97", "from_station": "%", "to_address": "+36202222222", "to_station": "%", "text": "Hello world 2", "create_date": "2021-07-13 12:46:23", "valid_until": "2021-07-20 12:46:23", "time_to_send": "2021-07-13 12:46:23", "submit_report_requested": true, "delivery_report_requested": false, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" }, { "message_id": "5f7f0290-172a-446e-a9fe-cf6b22c84fe6", "from_station": "%", "to_address": "+36203333333", "to_station": "%", "text": "Hello world 3", "create_date": "2021-07-13 12:46:23", "valid_until": "2021-07-20 12:46:23", "time_to_send": "2021-07-13 12:46:23", "submit_report_requested": true, "delivery_report_requested": false, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" } ] } }
Kako poslati SMS iz R koristeći R SMS API (Video tutorial)
Ovaj video vam pokazuje kako preuzeti datoteku SendMultipleSms.R.zip s ove stranice. Ako pogledate video, primijetit ćete da su sadržaji SendMultipleSms.R.zip datoteke smješteni na radnu površinu Windowsa. Također ćete vidjeti da pokrećemo naredbeni redak kako bismo poslali SMS.
R SMS primjer: SendMultipleSms.R
Primjer koda u nastavku dio je datoteke SendMultipleSms.R.
Kako provjeriti je li SMS prihvaćen od strane HTTP korisnika
Nakon što je SMS poslan, dobro je provjeriti vaš SMS gateway kako biste vidjeli što je primio. Dnevnik možete provjeriti otvaranjem detalja HTTP korisnika iz upravljačke konzole Ozeki SMS Gatewaya. Sljedeći video vam pokazuje na što trebate obratiti pažnju.
Zaključak
Ovaj članak ima za cilj objasniti korake za slanje višestrukih SMS poruka u R uz pomoć Ozeki SMS Gatewaya. Ovo rješenje je savršeno za kontaktiranje više klijenata s jednim R kodom. Preporuča se koristiti ovo znanje kako bi se postigla visoka učinkovitost u dijeljenju informacija. Ozeki SMS Gateway omogućuje prijavu SMS poruka u bazu podataka i nudi nekoliko mogućnosti izvještavanja kako bi pružio informacije o porukama.
Nastavite čitanje na Ozekijevoj stranici s tutorijalima, gdje možete pronaći više informacija o temama poput brisanja SMS poruka u R-u.
Jedino što sada preostaje je preuzeti Ozeki SMS Gateway i početi raditi!
More information
- R pošalji SMS s HTTP REST API-jem (primjer koda)
- R pošalji više SMS-ova s HTTP REST API-jem (primjer koda)
- R zakazani SMS s HTTP REST API-jem (primjer koda)
- R primi SMS s HTTP REST API-jem (primjer koda)
- R obriši SMS s HTTP REST API-jem (primjer koda)
- Kako preuzeti najnoviju R SMS biblioteku s Githuba