Kako poslati više SMS poruka iz Perla

Najjednostavniji način za slanje više SMS poruka iz Perla 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 telefonski broj primatelja i vratit će HTTP 200 OK odgovor na vaš zahtjev.

kako poslati više SMS poruka iz Perla
Slika 1 - Kako poslati više SMS poruka iz Perla

Perl kod za slanje više SMS poruka na mobilni telefon

Perl SMS primjer koda ispod pokazuje kako možete poslati SMS koristeći http rest SMS API Ozeki SMS Gatewaya koristeći Perl 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.pl
use Ozeki::Libs::Rest::Configuration;
use Ozeki::Libs::Rest::MessageApi;
use Ozeki::Libs::Rest::Message;

my $configuration = new Ozeki::Libs::Rest::Configuration();
$configuration->{ Username } = "http_user";
$configuration->{ Password } = "qwe123";
$configuration->{ ApiUrl } = "http://127.0.0.1:9509/api";

my $msg1 = new Ozeki::Libs::Rest::Message();
$msg1->{ ToAddress } = "+36201111111";
$msg1->{ Text } = "Hello world 1";

my $msg2 = new Ozeki::Libs::Rest::Message();
$msg2->{ ToAddress } = "+36202222222";
$msg2->{ Text } = "Hello world 2";

my $msg3 = new Ozeki::Libs::Rest::Message();
$msg3->{ ToAddress } = "+36203333333";
$msg3->{ Text } = "Hello world 3";

my $api = new Ozeki::Libs::Rest::MessageApi($configuration);

my $result = $api->Send(( $msg1, $msg2, $msg3 ));

print($result->stringify);

Kako koristiti Perl SMS primjer:

Ovaj Perl SMS primjer može se koristiti u bilo kojoj Perl aplikaciji. Da biste ga koristili, morate dodati Ozeki.Libs.Rest biblioteku u svoj projekt. Nakon što je biblioteka dodana, morate staviti direktivu using Ozeki.Libs.Rest; u zaglavlje vašeg Perl 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 poruka SMS gatewayu. SMS gateway će proslijediti vašu poruku mobilnoj mreži bilo putem bežične veze ili putem interneta.

Preuzmite SendMultipleSms.pl

Izvorni kod objašnjen u ovom članku može se preuzeti, koristiti i mijenjati besplatno.
Preuzmi: SendMultipleSms.pl.zip (76.1Kb)

Što se nalazi u datoteci SendMultipleSms.pl?

Datoteka SendMultipleSms.pl sadrži Ozeki.Libs.Rest biblioteku, koja vam daje sve alate potrebne za slanje i primanje SMS poruka. Također ćete pronaći datoteku SendMultipleSms u zip datoteci, koja sadrži primjer koda koji pokazuje kako poslati SMS. Ovaj primjer koda je naveden ispod.

Slika 2 - Što se nalazi unutar SendMultipleSms.pl.zip

Kako poslati više SMS poruka iz Perla (Brzi koraci)

Da biste poslali više SMS poruka iz Perla:

  1. Postavite Strawberry Perl
  2. Preuzmite datoteku SendMultipleSms.pl.zip
  3. Raspakirajte .zip datoteku iz mape Preuzimanja
  4. Otvorite datoteku SendSms.pl u Notepadu ili Visual Studio Codeu
  5. Pokrenite Ozeki SMS Gateway
  6. Kreirajte HTTP API korisnika u Ozekiju
  7. Pokrenite Perl kod SendMultipleSms.pl u naredbenom retku
  8. Provjerite poslane poruke u Ozeki SMS Gatewayu

Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika

Da biste mogli slati SMS iz Perla, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu na kojem razvijate svoj Perl kod u Visual studiju. Nakon instalacije, sljedeći korak je povezati Ozeki SMS Gateway 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 Perl kod.

HTTP API URL za slanje SMS iz Perla

Da biste poslali SMS iz Perla, vaš Perl ć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 Perl 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 iz Perla

Da biste autentificirali Perl 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 Perlu možete koristiti sljedeći kod za ovo kodiranje:

my ($self, $Username, $Password) = @_;
my $Username_Password = "${Username}:${Password}";
my $Username_Password_encoded = encode_base64($Username_Password);
return "Basic ${Username_Password_encoded}";

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 Perla

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.

Content-Type: application/json
Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==

HTTP zahtjev za slanje SMS-a iz Perla

Za slanje SMS-a, vaša Perl 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 broj primatelja i tekst poruke.


HTTP odgovor primljen u Perl 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 koja vam pruža 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, 02 Jul 2021 16:00:35 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": "ab4c1e78-db41-11eb-8298-c00c4d4e2ea7",
	      "from_station": "%",
	      "to_address": "+36201111111",
	      "to_station": "%",
	      "text": "Pozdrav svijete 1",
	      "create_date": "2021-07-02 14:27:45",
	      "valid_until": "2021-07-09 14:27:45",
	      "time_to_send": "2021-07-02 14:27:45",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": false,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ],
	      "status": "SUCCESS"
	    },
	    {
	      "message_id": "ab4c4523-db41-11eb-838d-c00c4d4e2ea7",
	      "from_station": "%",
	      "to_address": "+36202222222",
	      "to_station": "%",
	      "text": "Pozdrav svijete 2",
	      "create_date": "2021-07-02 14:27:45",
	      "valid_until": "2021-07-09 14:27:45",
	      "time_to_send": "2021-07-02 14:27:45",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": false,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ],
	      "status": "SUCCESS"
	    },
	    {
	      "message_id": "ab4c59cd-db41-11eb-82c0-c00c4d4e2ea7",
	      "from_station": "%",
	      "to_address": "+36203333333",
	      "to_station": "%",
	      "text": "Pozdrav svijete 3",
	      "create_date": "2021-07-02 14:27:45",
	      "valid_until": "2021-07-09 14:27:45",
	      "time_to_send": "2021-07-02 14:27:45",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": false,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ],
	      "status": "SUCCESS"
	    }
	  ]
}

Primjer SMS-a u Perlu: SendMultipleSms.pl

U ovom videu vidjet ćete proces preuzimanja i postavljanja projekta SendMultipleSMS.pl. Počet će s preuzimanjem projekta i završit će s postavljanjem. Naučit ćete sve korake postavljanja koje trebate napraviti kako biste imali funkcionalno rješenje. Video je dug 1:44, ali prikazuje sve korake na vrlo detaljan način. Nakon gledanja, možete samostalno preuzeti i postaviti rješenje.

Video 1 - Kako preuzeti i postaviti gore navedeno rješenje (Video vodič)

Primjer koda

Na slici 3 možete vidjeti primjer koda. Ovaj primjer koda će poslati više SMS poruka na više primatelja. Ako ste upoznati s programskim jezikom Perl, slobodno izmijenite kod prema vlastitim željama. Poslat će SMS na sve telefonske brojeve pohranjene kao varijabla 'ToAddress', s tekstom pohranjenim u varijablama Text.

Slika 3 - SendMultipleSms.pl

Kako koristiti primjernu projektnu datoteku (Video vodič)

U ovom videu vidjet ćete primjer projekta u akciji. Pokazat ćemo vam što trebate učiniti kako bi projekt poslao više SMS poruka samo jednim pokretanjem. Video je dug samo 1:12 i sadrži sve informacije koje su vam potrebne za pokretanje programa. Počet će s otvorenim projektom i završit će s poslanim svim porukama.

Video 2 - Kako koristiti datoteku SendMultipleSms.pl (Video vodič)

Sažetak

Gornji vodič objasnio je korake slanja više SMS poruka u Perlu s Ozeki SMS Gatewayom. Ako ste pažljivo slijedili svaki korak, trebali biste biti u mogućnosti kontaktirati više klijenata s jednim Perl kodom i Ozeki SMS Gatewayom. S ovim rješenjem, veliki broj korisnika može istovremeno primiti svoje SMS poruke. Važno je napomenuti da Ozeki SMS Gateway nudi visoke performanse, što znači da može poslati do 1000 SMS poruka u sekundi.

Pobrinite se da ne završite čitanje ovdje, posjetite Ozekijevu stranicu s vodičima gdje možete pronaći više informacija o sličnim temama, poput planiranja SMS-ova u Perlu.

Jedino što sada preostaje jest preuzeti Ozeki SMS Gateway i neka počne rad!

More information