Kako primiti SMS iz Perla

Najjednostavniji način za primanje SMS poruka iz Perla je korištenje ugrađenog HTTP/Rest SMS API-ja Ozeki SMS Gatewaya. Kada koristite ovaj API, slati ć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 primatelju na telefon i vratiti HTTP 200 OK odgovor na vaš zahtjev.

kako primiti sms iz perla
Slika 1 - Kako primiti SMS iz Perla

Perl kod za primanje SMS-a s mobitela

Perl SMS kod primjer ispod pokazuje kako možete primati SMS koristeći http rest sms api Ozeki SMS Gatewaya koristeći Perl Ozeki.Libs.Rest biblioteku. Ova biblioteka vam je dostupna besplatno, a možete je koristiti i mijenjati u bilo kojem od vaših projekata.

ReceiveSms.pl
use Ozeki::Libs::Rest::Configuration;
use Ozeki::Libs::Rest::MessageApi;

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

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

my $result = $api->DownloadIncoming();

print($result->stringify, "\n");

foreach my $message (@{ $result->{ messages } }) {
    print($message->stringify, "\n");
}

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 se biblioteka doda, 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-a. Možete koristiti klasu MessageApi za primanje SMS poruka na SMS gateway. SMS gateway će proslijediti vašu poruku na mobilnu mrežu bilo putem bežične veze ili putem interneta.

Preuzmite ReceiveSms.pl

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

Što se nalazi u ReceiveSms.pl.zip datoteci?

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

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

Kako primiti SMS u Perlu (Jednostavne smjernice)

Za primanje SMS-a u Perlu:

  1. Preuzmite datoteku ReceiveSms.pl.zip
  2. Ekstrahirajte .zip datoteku iz Preuzimanja
  3. Otvorite datoteku ReceiveSms.pl u uređivaču teksta
  4. Pokrenite Ozeki SMS Gateway
  5. Kliknite na HTTP korisnika u kartici Korisnici i aplikacije
  6. Pokrenite ReceiveSms.pl za primanje SMS-a koristeći naredbeni redak
  7. Provjerite Inbox u Ozeki SMS Gatewayu

Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika

Da biste mogli slati i primati 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-a kako biste potvrdili da vaša mobilna mrežna veza radi. Posljednji 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 primanje SMS-a iz Perla

Za slanje SMS-a 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 primanje SMS-a iz Perla

Za autentifikaciju Perl 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 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 zahtjev za primanje SMS-a s Perlom

Da biste primili SMS, vaša Perl aplikacija će poslati HTTP zahtjev sličan donjem. 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.

GET /api?action=receivemsg&folder=inbox HTTP/1.1
Connection: TE, close
Content-Type: application/json
Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw==
Host: 192.168.0.14:9509
Te: deflate,gzip;q=0.3
User-Agent: libwww-perl/6.43
	

HTTP zaglavlje zahtjeva za primanje SMS-a iz C#

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 odgovor primljen Perl SMS primjerom

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žila korisne detalje 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": "",
	"data": {
	  "folder": "inbox",
	  "limit": "1000",
	  "data": [
	    {
	      "message_id": "a860555d-db45-11eb-82d5-c00c4d4e2ea7",
	      "from_connection": "http_user@localhost",
	      "from_address": "+36201111111",
	      "from_station": "%",
	      "to_connection": "http_user@localhost",
	      "to_address": "http_user",
	      "to_station": "%",
	      "text": "Hello world 1",
	      "create_date": "2021-07-02 14:56:18",
	      "valid_until": "2021-07-09 14:56:18",
	      "time_to_send": "2021-07-02 14:56:18",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": true,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ]
	    },
	    {
	      "message_id": "a8607b04-db45-11eb-818e-c00c4d4e2ea7",
	      "from_connection": "http_user@localhost",
	      "from_address": "+36202222222",
	      "from_station": "%",
	      "to_connection": "http_user@localhost",
	      "to_address": "http_user",
	      "to_station": "%",
	      "text": "Hello world 2",
	      "create_date": "2021-07-02 14:56:18",
	      "valid_until": "2021-07-09 14:56:18",
	      "time_to_send": "2021-07-02 14:56:18",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": true,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ]
	    },
	    {
	      "message_id": "a8609539-db45-11eb-80db-c00c4d4e2ea7",
	      "from_connection": "http_user@localhost",
	      "from_address": "+36203333333",
	      "from_station": "%",
	      "to_connection": "http_user@localhost",
	      "to_address": "http_user",
	      "to_station": "%",
	      "text": "Hello world 3",
	      "create_date": "2021-07-02 14:56:18",
	      "valid_until": "2021-07-09 14:56:18",
	      "time_to_send": "2021-07-02 14:56:18",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": true,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ]
	    }
	  ]
	}
}

Kako primiti SMS s Perlom koristeći Perl SMS API (Video tutorial)

Ovi videozapisi pokazat će vam kako instalirati Ozeki::Libs::Rest modul i kako koristiti primjer programa ReceiveSms.pl. Video će vam pokazati kako možete preuzeti mapu projekta ReceiveSMS.pl, kako postaviti sustav koji možete početi koristiti. Video traje samo 1:30, ali sadrži sve korake koje trebate poduzeti. Tutorial je jasan i lako ga je pratiti tako da nećete imati problema s ponavljanjem procesa.

Video 1 - Kako preuzeti i postaviti primjer rješenja (Video tutorial)

Perl SMS primjer: ReceiveSms.pl

Na slici 3 možete vidjeti izvorni kod ReceiveSMS.pl. Ovaj kod će preuzeti sve dolazne poruke s poslužitelja i ispisati ih na zaslon. Potrebno je navesti vjerodajnice za prijavu na poslužitelj u varijablama 'Username' i 'Password'. Ako ste upoznati s Perl programskim jezikom, slobodno izmijenite kod kako bi savršeno odgovarao vašim potrebama.

Slika 3 - ReceiveSms.pl

Kako primiti SMS s Perl kodom (Video tutorial)

U ovom videu vidjet ćete kod na djelu. Pokazat ćemo vam kako pokrenuti kod i provjeriti njegove rezultate. Počet će s otvorenim terminalom i otvorenim kodom te će vas odvesti do čitanja primljenih poruka. Video traje samo 1 minutu, a lako ga je pratiti. Nećete imati problema s praćenjem koraka.

Video 2 - Kako primiti SMS s gornjim Perl kodom (Video tutorial)

Da sumiramo

Ovaj članak je objasnio kako primati SMS poruke iz Perla koristeći ugrađeni HTTP REST SMS API Ozeki SMS Gatewaya. Ako ste pažljivo pratili tutorial, sada možete kreirati HTTP korisnika u Ozeki SMS Gatewayu i koristiti dano spremište za primanje SMS poruka s Perl SMS API-jem. Ova knjižnica vam je dostupna besplatno, a možete je koristiti i mijenjati u bilo kojem od svojih projekata.

Što više znanja imate, to možete biti učinkovitiji, stoga nastavite s čitanjem. Pogledajte članak Kako preuzeti najnoviju Perl SMS knjižnicu s Githuba i naučite kako šire koristiti Perl SMS API.

Preuzmite Ozeki SMS Gateway sada i neka počne rad!

More information