Kako poslati više SMS poruka iz Tcl/Tk
Najjednostavniji način za slanje više SMS poruka iz Tcl/Tk 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.

Tcl/Tk kod za slanje SMS poruka na mobilni telefon
Tcl/Tk SMS primjer koda ispod pokazuje kako možete poslati više SMS poruka koristeći http rest SMS API Ozeki SMS Gatewaya koristeći Tcl/Tk Ozeki.Libs.Rest biblioteku. Ova biblioteka vam je dostupna besplatno i možete je koristiti i mijenjati u bilo kojem od vaših projekata.
SendMultipleSms.tcl1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
source Ozeki.Libs.Rest.tcl set configuration [ Configuration new ] $configuration setUsername "http_user" $configuration setPassword "qwe123" $configuration setApiUrl "http://127.0.0.1:9509/api" set msg1 [ Message new ] $msg1 setToAddress "+36201111111" $msg1 setText "Pozdrav svijete 1" set msg2 [ Message new ] $msg2 setToAddress "+36202222222" $msg2 setText "Pozdrav svijete 2" set msg3 [ Message new ] $msg3 setToAddress "+36203333333" $msg3 setText "Pozdrav svijete 3" set api [ MessageApi new $configuration ] set messages [list] lappend messages $msg1 lappend messages $msg2 lappend messages $msg3 set result [ $api send $messages ] puts [ $result toString ] |
Kako koristiti Tcl/Tk SMS primjer:
Ovaj Tcl/Tk SMS primjer može se koristiti u bilo kojoj Tcl/Tk aplikaciji. Da biste ga koristili, morate dodati datoteku Ozeki.Libs.Rest.tcl u svoj projekt. Nakon dodavanja datoteke, morate staviti izravnu naredbu source Ozeki.Libs.Rest.tcl u zaglavlje svog Tcl/Tk izvornog koda. 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 poruke SMS gatewayu. SMS gateway će proslijediti vašu poruku mobilnoj mreži bilo putem bežične veze ili putem interneta.
Preuzmite SendMultipleSms.tcl
Izvorni kod objašnjen u ovom članku može se besplatno preuzeti, koristiti i mijenjati.
Preuzimanje: SendMultipleSms.tcl.zip (4.17Kb)
Što se nalazi u datoteci SendMultipleSms.tcl.zip?
Datoteka SendMultipleSms.tcl.zip sadrži Ozeki.Libs.Rest biblioteku, koja vam daje sve potrebne alate za slanje i primanje SMS poruka. Također ćete pronaći projekt SendMultipleSms u zip datoteci, koji sadrži primjer koda koji pokazuje kako poslati SMS poruku. Ovaj primjer koda je naveden ispod.

Kako poslati SMS iz Tcl/Tk (Jednostavne smjernice)
Za slanje SMS poruka iz Tcl/Tk:
- Instalirajte HTTP API korisnika
- Omogućite bilježenje komunikacijskih događaja na kartici Napredno
- Preuzmite i instalirajte Tcllib biblioteku
- Preuzmite zatim raspakirajte datoteku SendMultipleSms.tcl.zip
- Otvorite datoteku SendMultipleSms.tcl u uređivaču teksta
- Pokrenite Ozeki SMS Gateway aplikaciju
- Pokrenite SendMultipleSms.tcl Tcl/Tk kod u terminalu
- Provjerite zapisnike da vidite je li SMS poslan
Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika
Da biste mogli slati SMS poruke iz Tcl/Tk, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu na kojem razvijate svoj Tcl/Tk kod u Visual studiju. Nakon instalacije, sljedeći korak je povezivanje Ozeki SMS Gatewaya s mobilnom mrežom. Možete poslati testnu SMS poruku iz Ozeki GUI-a 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 Tcl/Tk kod.
HTTP API URL za slanje SMS poruka iz Tcl/Tk
Da biste poslali SMS poruku iz Tcl/Tk, vaš Tcl/Tk ć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 Tcl/Tk SMS aplikacija, ovo može biti 127.0.0.1. Ako je instaliran na drugom računalu, treba biti IP adresa tog računala.
1 2 |
http: //127.0.0.1:9509/api?action=rest |
HTTP autentifikacija za slanje SMS poruka iz Tcl/Tk
Da biste autentificirali Tcl/Tk 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 Tcl/Tk možete koristiti sljedeći kod za ovu kodiranje:
1 2 3 4 |
set usernamePassword "$username:$password" set usernamePasswordEncoded [ binary encode base64 $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 Tcl/Tk
Za 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.
1 2 3 |
Content-Type: application/json Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ== |
HTTP zahtjev za slanje SMS-a iz Tcl/Tk
Za slanje SMS-a, vaša Tcl/Tk 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.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
POST /api?action=sendmsg HTTP/1.1 Host: 127.0.0.1:9509 User-Agent: Mozilla/5.0 (Windows; U; Windows NT 10.0) http/2.9.0 Tcl/8.6.9 Connection: close Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw== Accept: */* Accept-Encoding: gzip,deflate,compress Content-Type: application/json Content-Length: 935 { "messages" : [ { "message_id" : "dbaf5396-a220-424b-bb17-534dc6a92c34" , "to_address" : "+36201111111" , "text" : "Hello world 1" , "create_date" : "2021-08-04T10:28:14" , "valid_until" : "2021-08-11T10:28:14" , "time_to_send" : "2021-08-04T10:28:14" , "submit_report_requested" : true , "delivery_report_requested" : true , "view_report_requested" : true }, { "message_id" : "b884f2c3-555b-416e-bcd4-5d7c653ec3ba" , "to_address" : "+36202222222" , "text" : "Hello world 2" , "create_date" : "2021-08-04T10:28:14" , "valid_until" : "2021-08-11T10:28:14" , "time_to_send" : "2021-08-04T10:28:14" , "submit_report_requested" : true , "delivery_report_requested" : true , "view_report_requested" : true }, { "message_id" : "911092b2-4338-4dc7-97f6-1939a99779f7" , "to_address" : "+36203333333" , "text" : "Hello world 3" , "create_date" : "2021-08-04T10:28:14" , "valid_until" : "2021-08-11T10:28:14" , "time_to_send" : "2021-08-04T10:28:14" , "submit_report_requested" : true , "delivery_report_requested" : true , "view_report_requested" : true } ] } |
HTTP odgovor primljen od Tcl/Tk 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.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 |
HTTP/1.1 200 OK Transfer-Encoding: chunked Content-Type: application/json; charset=utf8 Last-Modified: Wed, 04 Aug 2021 08:44:43 GMT Server: 10/10.3.124 Microsoft-HTTPAPI/2.0 User-Agent: OZEKI 10.3.124 (www.myozeki.com) Access-Control-Allow-Origin: * Date: Wed, 04 Aug 2021 08:28:14 GMT Connection: close { "http_code" : 200, "response_code" : "SUCCESS" , "response_msg" : "Messages queued for delivery." , "data" : { "total_count" : 3, "success_count" : 3, "failed_count" : 0, "messages" : [ { "message_id" : "dbaf5396-a220-424b-bb17-534dc6a92c34" , "from_station" : "%" , "to_address" : "+36201111111" , "to_station" : "%" , "text" : "Hello world 1" , "create_date" : "2021-08-04 10:28:14" , "valid_until" : "2021-08-11 10:28:14" , "time_to_send" : "2021-08-04 10:28:14" , "submit_report_requested" : true , "delivery_report_requested" : true , "view_report_requested" : false , "tags" : [ { "name" : "Type" , "value" : "SMS:TEXT" } ], "status" : "SUCCESS" }, { "message_id" : "b884f2c3-555b-416e-bcd4-5d7c653ec3ba" , "from_station" : "%" , "to_address" : "+36202222222" , "to_station" : "%" , "text" : "Hello world 2" , "create_date" : "2021-08-04 10:28:14" , "valid_until" : "2021-08-11 10:28:14" , "time_to_send" : "2021-08-04 10:28:14" , "submit_report_requested" : true , "delivery_report_requested" : true , "view_report_requested" : false , "tags" : [ { "name" : "Type" , "value" : "SMS:TEXT" } ], "status" : "SUCCESS" }, { "message_id" : "911092b2-4338-4dc7-97f6-1939a99779f7" , "from_station" : "%" , "to_address" : "+36203333333" , "to_station" : "%" , "text" : "Hello world 3" , "create_date" : "2021-08-04 10:28:14" , "valid_until" : "2021-08-11 10:28:14" , "time_to_send" : "2021-08-04 10:28:14" , "submit_report_requested" : true , "delivery_report_requested" : true , "view_report_requested" : false , "tags" : [ { "name" : "Type" , "value" : "SMS:TEXT" } ], "status" : "SUCCESS" } ] } } |
Kako poslati SMS iz Tcl/Tk koristeći Tcl/Tk SMS API (Video tutorial)
Ovaj video vam pokazuje kako preuzeti datoteku SendMultipleSms.tcl.zip s ove stranice i kako preuzeti njezin sadržaj u tekstualni editor. Ako pogledate video, primijetit ćete da je sadržaj SendMultipleSms.tcl zip datoteke smješten na Desktop. Također ćete vidjeti da dvoklikom na SendMultipleSms.tcl datoteku otvaramo Tcl skriptu.
Tcl/Tk SMS primjer: SendMultipleSms.tcl
Primjer koda u nastavku dio je datoteke SendMultipleSms.tcl.zip. U zip datoteci možete pronaći dvije datoteke: SendMultipleSms.tcl i Ozeki.Libs.Rest.tcl

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. Video će započeti s otvorenim kodom i završit će s detaljima poslane poruke. Naučit ćete kako pokrenuti projekt, kako projekt izgleda tijekom izvođenja i kako izgleda datoteka dnevnika nakon toga. Video traje samo 42 sekunde i lako ga je razumjeti. Nećete imati problema s praćenjem.