Kako poslati više SMS poruka iz Node.js

Jednostavan način za slanje SMS poruka iz Node.Js je korištenje ugrađenog HTTP/Rest SMS API-ja Ozeki SMS Gatewaya. Kada koristite ovaj API, slanje SMS poruka vršite putem HTTP Post zahtjeva prema SMS gatewayu. HTTP Post zahtjev će sadržavati poruku formatiranu u json formatu. SMS gateway će poslati ovu SMS poruku na telefonski broj primatelja i vratit će HTTP 200 OK odgovor na vaš zahtjev.

kako poslati sms poruke koristeći node js
Slika 1 - Kako poslati više SMS poruka iz Node.Js

JavaScript kod za slanje sms na mobilni telefon

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

SendMultipleSms.mjs
import { Configuration, Message, MessageApi } from './Ozeki.Libs.Rest.js';


var configuration = new  Configuration();
configuration.Username = "http_user";
configuration.Password = "qwe123";
configuration.ApiUrl = "http://127.0.0.1:9509/api";

var msg1 = new Message();
msg1.ToAddress = "+36201111111";
msg1.Text = "Pozdrav svijete 1";

var msg2 = new Message();
msg2.ToAddress = "+36202222222";
msg2.Text = "Pozdrav svijete 2";

var msg3 = new Message();
msg3.ToAddress = "+36203333333";
msg3.Text = "Pozdrav svijete 3";

var messages = new Array();

messages.push(msg1);
messages.push(msg2);
messages.push(msg3);

var api = new MessageApi(configuration);

const result = await api.Send(messages);

console.log(result.toString());
	

Kako koristiti JavaScript sms primjer:

Možete koristiti klasu Message za kreiranje SMS poruke i klasu MessageApi za slanje SMS-a prema SMS gatewayu. SMS gateway će proslijediti vašu poruku na mobilnu mrežu bilo putem bežične veze ili putem interneta.

Preuzmite SendMultipleSms.js

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

Što se nalazi u SendMultipleSms.js.zip datoteci?

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

primjer projekta za slanje više sms poruka s node js
Slika 2 - SendMultipleSms.js direktorij

Ovaj projekt ima ovisnosti, pa prije početka morate instalirati node-fetch paket sljedećom naredbom:

npm install node-fetch
	

Kod 1 - Naredba za instalaciju node-fetch paketa

.

Kako poslati SMS iz Node.Js (Brzi koraci)

Za slanje sms-a iz Node.Js:

  1. Instalirajte Ozeki SMS Gateway
  2. Povežite Ozeki SMS Gateway s mobilnom mrežom
  3. Pošaljite testni sms iz Ozeki GUI-a
  4. Kreirajte HTTP sms api korisnika
  5. Apache NetBeans
  6. Preuzmite gore navedeni primjer projekta
  7. Kreirajte SMS kreiranjem novog Message objekta
  8. Kreirajte api za slanje vaše poruke
  9. Koristite metodu Send za slanje vaše poruke
  10. Pročitajte odgovor poruke na konzoli
  11. Provjerite zapisnike u SMS gatewayu

Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika

Da biste mogli slati SMS iz Node.Js, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu na kojem razvijate svoj JavaScript kod u Visual Studio Code-u ili bilo kojem drugom uređivaču koda. Nakon instalacije, sljedeći korak je povezivanje Ozeki SMS Gatewaya s mobilnom mrežom. Možete poslati testni sms 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 korisnika. 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 JavaScript kod.

HTTP API url za slanje sms-a iz Node.Js

Za slanje SMS-a iz Node.Js, vaš JavaScript će morati poslati HTTP zahtjev prema 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 JavaScript 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 JavaScripta

Za autentifikaciju Node.Js SMS klijenta, potrebno je poslati korisničko ime i lozinku u base64 kodiranom stringu na server u HTTP zahtjevu. Korišteni format je: base64(korisničko_ime+":"+lozinka). U JavaScriptu možete koristiti sljedeći kod za to kodiranje:

var usernamePassword = username + ":" + password;
return `Basic ${Base64.encode(usernamePassword)}`;
	

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 JavaScripta

Za slanje SMS poruka, potrebno je uključiti sljedeće retke kao zaglavlja u HTTP zahtjev. Imajte na umu da uključujemo tip sadržaja i zaglavlje Autorizacije.

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

HTTP zahtjev za slanje SMS-a iz Node.Js

Za slanje SMS-a, vaša Node.Js 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 podatkovni string. Sadrži broj primatelja i tekst poruke.

POST /api?action=sendmsg HTTP/1.1
Connection: close
Content-Length: 932
Content-Type: application/json
Accept: */*
Accept-Encoding: gzip,deflate
Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw==
Host: 127.0.0.1:9509
User-Agent: node-fetch/1.0 (+https://github.com/bitinn/node-fetch)

{
	"messages":	[
		{
			"message_id":	"bda3e52a-6081-4c7e-954a-e3baf41d68bd",
			"to_address":	"+36201111111",
			"text":	"Pozdrav svijete 1",
			"create_date":	"2021-06-14T09:45:52",
			"vaild_date":	"2021-06-21T09:45:52",
			"time_to_send":	"2021-06-14T09:45:52",
			"submit_report_requested":	true,
			"delivery_report_requested":	true,
			"view_report_requested":	true
		},
		{
			"message_id":	"50147a56-d453-50ba-b0ba-567c789cb539",
			"to_address":	"+36202222222",
			"text":	"Pozdrav svijete 2",
			"create_date":	"2021-06-14T09:45:52",
			"vaild_date":	"2021-06-21T09:45:52",
			"time_to_send":	"2021-06-14T09:45:52",
			"submit_report_requested":	true,
			"delivery_report_requested":	true,
			"view_report_requested":	true
		},
		{
			"message_id":	"f05671e8-7664-d1c0-82da-0934464e2978",
			"to_address":	"+36203333333",
			"text":	"Pozdrav svijete 3",
			"create_date":	"2021-06-14T09:45:52",
			"vaild_date":	"2021-06-21T09:45:52",
			"time_to_send":	"2021-06-14T09:45:52",
			"submit_report_requested":	true,
			"delivery_report_requested":	true,
			"view_report_requested":	true
		}
	]
}
	

HTTP odgovor primljen od JavaScript 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 detalje o slanju poruke.

HTTP/1.1 200 OK
User-Agent: OZEKI 10.3.120 (www.myozeki.com)
Content-Type: application/json; charset=utf8
Last-Modified: Mon, 14 Jun 2021 09:12:00 GMT
Server: 10/10.3.120
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": "bda3e52a-6081-4c7e-954a-e3baf41d68bd",
	      "from_station": "%",
	      "to_address": "+36201111111",
	      "to_station": "%",
	      "text": "Pozdrav svijete 1",
	      "create_date": "2021-06-14 09:45:52",
	      "valid_until": "2021-06-21 09:45:52",
	      "time_to_send": "2021-06-14 09:45:52",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": false,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ],
	      "status": "SUCCESS"
	    },
	    {
	      "message_id": "50147a56-d453-50ba-b0ba-567c789cb539",
	      "from_station": "%",
	      "to_address": "+36202222222",
	      "to_station": "%",
	      "text": "Pozdrav svijete 2",
	      "create_date": "2021-06-14 09:45:52",
	      "valid_until": "2021-06-21 09:45:52",
	      "time_to_send": "2021-06-14 09:45:52",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": false,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ],
	      "status": "SUCCESS"
	    },
	    {
	      "message_id": "f05671e8-7664-d1c0-82da-0934464e2978",
	      "from_station": "%",
	      "to_address": "+36203333333",
	      "to_station": "%",
	      "text": "Pozdrav svijete 3",
	      "create_date": "2021-06-14 09:45:52",
	      "valid_until": "2021-06-21 09:45:52",
	      "time_to_send": "2021-06-14 09:45:52",
	      "submit_report_requested": true,
	      "delivery_report_requested": true,
	      "view_report_requested": false,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ],
	      "status": "SUCCESS"
	    }
	  ]
	}
}
	

Kako poslati SMS iz Node.Js koristeći SMS API (Video tutorial)

Ovaj video vam pokazuje kako preuzeti i koristiti projekt SendMultipleSms.js. Nakon što dodate potrebne datoteke u svoj projekt, možda ćete primijetiti da postoji datoteka pod nazivom Ozeki.Lbis.Rest.js. Ovo je datoteka koja sadrži MessageApi i sve što vam je potrebno za slanje SMS-a koristeći JavaScript.

Video 1 - Kako preuzeti Ozeki.Libs.Rest i postaviti svoj projekt (Video tutorial)

Node.Js primjer SMS-a: SendMultipleSms.mjs (u Notepadu)

Na ovoj slici (Slika 3), možete pronaći izvorni kod projekta, otvoren u Notepadu. Također možete uređivati u Notepadu. Ako ste upoznati s Node.js-om, slobodno promijenite varijable u kodu i pošaljite prilagođenu poruku na adresu po vašem izboru.

javascript primjer za slanje više SMS-ova
Slika 3 - SendMultipleSms.mjs u Notepadu

Node.Js primjer SMS-a: SendMultipleSms.mjs (u Visual Studio Codeu)

Ako tražite lakši način za otvaranje i uređivanje izvornog koda, pokušajte koristiti Visual Studio Code (Slika 4). Nudi vam bojanje koda, više pomoći i automatsko dopunjavanje. To je lagano IDE (Integrirano razvojno okruženje) koje je otvorenog koda i besplatno za korištenje.

javascript primjer za slanje više SMS-ova
Slika 4 - SendMultipleSms.mjs u Visual Studio Codeu

Kako provjeriti je li SMS prihvaćen od strane HTTP korisnika

Nakon što je SMS poslan, dobro je provjeriti vaš 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 2 - Kako poslati više SMS poruka s gore navedenim JavaScript kodom (Video tutorial)

Kako provjeriti je li SMS poslan na mobilnu mrežu

Zadnji korak u provjeri postupka je pogledati dnevnike veze s mobilnom mrežom. Možda ćete morati uključiti bilježenje u konfiguraciji veze prije slanja poruke kako biste vidjeli dnevnike. Ako je bilježenje uključeno, vidjet ćete broj telefona i tekst poruke koju ste poslali.

Zaključne misli

Ovaj vodič sadrži sve bitne informacije za učenje kako poslati više SMS poruka iz Node.js aplikacije s HTTP korisnikom Ozeki SMS pristupnika. Ovo rješenje nudi svestranu upotrebu jer Node.js SMS API radi i s Android SMS pristupnikom koji vam omogućuje bežično slanje SMS-ova, što ćete smatrati prednošću. Korištenje ove usluge čini vaše poruke učinkovitijim i dinamičnijim jer vam omogućuje dostavu vrijednih informacija i važnih obavijesti na više mobilnih telefona odjednom.

Na Ozeki web stranici možete pronaći mnogo više članaka o Node.js SMS API funkcionalnostima. Idite, naučite više sada, nastavite s Kako zakazati SMS u Node.js-u.

Krenimo na posao, prije svega, preuzmite Ozeki SMS pristupnik!

More information