Kako zakazati SMS u C/C++

Najjednostavniji način za slanje SMS-a iz C/C++ 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. (Slika 1)

kako zakazati sms u ccpp
Slika 1 - Kako zakazati SMS u C/C++

C/C++ kod za slanje zakazanog SMS-a na mobilni telefon

Donji C/C++ SMS primjer koda pokazuje kako možete poslati SMS koristeći HTTP REST SMS API Ozeki SMS Gatewaya s C++ Ozeki.Libs.Rest bibliotekom. Ova biblioteka vam je dostupna besplatno i možete je koristiti i mijenjati u bilo kojem od vaših projekata.

SendScheduledSms.cpp
#include 
#include 
#include "Ozeki.Libs.Rest.h"

using namespace std;

int main()
{
    //Funkcija za stvaranje jedinstvenog identifikatora za svaku poruku
    srand((unsigned)time(0));

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

    Message msg;
    msg.ToAddress = "+36201111111";
    msg.Text = "Pozdrav svijete!";
    msg.TimeToSend = localdatetime(2021, 6, 29, 10, 0, 0);

    MessageApi api(configuration);

    auto result = api.Send(msg);

    cout << result << endl;

    return 0;
}
	

Kako koristiti C/C++ SMS primjer:

Ovaj C/C++ SMS primjer može se koristiti u bilo kojoj C ili C++ aplikaciji. Da biste ga koristili, morate dodati Ozeki.Libs.Rest dll kao referencu u vaš projekt. Nakon dodavanja reference u projekt, morate staviti direktivu using Ozeki.Libs.Rest; u zaglavlje vašeg C/C++ izvornog koda. To će vam omogućiti korištenje klasa dostupnih u Ozeki.Libs.Rest biblioteci. Možete koristiti klasu Message za stvaranje SMS-a. 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.

Video 1 - Kako preuzeti i postaviti primjer projekta iznad (Video tutorial)

Preuzmite SendScheduledSms.cpp

Izvorni kod objašnjen u ovom članku može se preuzeti, koristiti i mijenjati besplatno.
Preuzimanje: SendScheduledSms.cpp.zip (2.97Mb)

Što se nalazi u datoteci SendScheduledSms.cpp?

Datoteka SendScheduledSms.cpp sadrži Ozeki.Libs.Rest biblioteku, koja vam daje sve alate potrebne za slanje i primanje SMS poruka. Također ćete pronaći SendScheduledSms projekt u zip datoteci, koji sadrži primjer koda koji pokazuje kako poslati zakazani SMS. Ovaj primjer koda je naveden ispod. (Slika 2)

primjer projekta za slanje zakazanih sms poruka koristeći c plus plus
Slika 2 - Što se nalazi unutar SendScheduledSms.cpp.zip

Kako poslati zakazani SMS iz C/C++ (Jednostavne smjernice)

Za slanje zakazanog SMS-a iz C/C++:

  1. Instalirajte HTTP API korisnika
  2. Postavite Visual Studio
  3. Preuzmite datoteku SendScheduledSms.cpp.zip
  4. Raspakirajte .zip datoteku iz mape Preuzimanja
  5. Otvorite datoteku SendScheduledSms.sln u Visual Studiju
  6. Dodajte Ozeki.Libs.Rest dll kao referencu
  7. Uredite datoteku za zakazivanje SMS-a iz C/C++
  8. Pokrenite Ozeki SMS Gateway
  9. Pokrenite SendScheduledSms.cpp u Visual Studiju za slanje SMS-a iz C/C++
  10. Provjerite zapisnike

Instalirajte Ozeki SMS Gateway i stvorite HTTP API korisnika

Da biste mogli slati SMS iz C/C++, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu na kojem razvijate svoj C/C++ kod u Visual Studiju. 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 stvaranje HTTP SMS API korisničkog računa. Stvorite korisnika s korisničkim imenom "http_user" i lozinkom "qwe123" kako bi primjer radio bez izmjena.

Nakon postavljanja okruženja, možete pokrenuti svoj C/C++ kod.

HTTP API URL za slanje SMS-a iz C/C++

Za slanje SMS-a iz C/C++, vaš C/C++ ć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 C/C++ 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 C/C++

Za autentifikaciju C/C++ 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 C++ možete koristiti sljedeći kod za ovu enkodiranje:

string usernamePassword = username + ":" + password;
string usernamePasswordEncoded = base64::encode(usernamePassword);
return "Basic " + usernamePasswordEncoded;
	

Na primjer, ako enkodirate 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 C/C++

Za slanje SMS poruka, potrebno je uključiti sljedeće retke kao zaglavlja u HTTP zahtjev. Imajte na umu da uključujemo Content-Type i Authorization zaglavlje.

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

HTTP zahtjev za slanje planiranog SMS-a iz C/C++

Za slanje SMS-a, vaša C/C++ aplikacija će poslati HTTP zahtjev sličan donjem primjeru. Imajte na umu da ovaj zahtjev sadrži dio HTTP zaglavlja i dio tijela HTTP-a. Tijelo HTTP-a je JSON kodirani podatkovni string. Sadrži broj primatelja i tekst poruke.

POST /api?action=sendmsg HTTP/1.1
Content-Length: 320
Content-Type: application/json
Accept: application/json
Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw==
Host: 127.0.0.1:9509

{
	"messages":	[
		{
			"create_date":	"2021-06-29T10:21:47",
			"message_id":	"gi0j9bk6-y7wv-35qq-tksz-nzgwbc2sxznq",
			"submit_delivery_requested":	true,
			"submit_report_requested":	true,
			"submit_view_requested":	true,
			"text":	"Hello world!",
			"time_to_send":	"2021-06-29T10:30:00",
			"to_address":	"+36201111111",
			"valid_until":	"2021-07-06T10:21:47"
		}
	]
}
	

HTTP odgovor primljen u C/C++ 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 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: Tue, 29 Jun 2021 10:13:46 GMT
Server: 10/10.3.123
Transfer-Encoding: chunked

{
	"http_code": 200,
	"response_code": "SUCCESS",
	"response_msg": "Messages queued for delivery.",
	"data": {
	  "total_count": 1,
	  "success_count": 1,
	  "failed_count": 0,
	  "messages": [
	    {
	      "message_id": "gi0j9bk6-y7wv-35qq-tksz-nzgwbc2sxznq",
	      "from_station": "%",
	      "to_address": "+36201111111",
	      "to_station": "%",
	      "text": "Hello world!",
	      "create_date": "2021-06-29 10:21:47",
	      "valid_until": "2021-07-06 10:21:47",
	      "time_to_send": "2021-06-29 10:30:00",
	      "submit_report_requested": true,
	      "delivery_report_requested": false,
	      "view_report_requested": false,
	      "tags": [
	        {
	          "name": "Type",
	          "value": "SMS:TEXT"
	        }
	      ],
	      "status": "SUCCESS"
	    }
	  ]
	}
}
	

C/C++ SMS primjer: SendScheduledSms.sln

Primjer koda u nastavku dio je SendScheduledSms.sln Visual Studio Solution. Visual Studio rješenje može sadržavati više projekata i više datoteka. U ovom rješenju postoji samo jedan projekt: SendScheduledSms.vcxproj, i jedna datoteka: SendScheduledSms.cpp.

rješenje za slanje planiranih SMS poruka koristeći C plus plus
Slika 3 - SendScheduledSms.sln

Kako poslati planirani SMS s C++ kodom (Video tutorijal)

Sljedeći video objašnjava kako zakazati SMS s C/C++ kodom. Video počinje otvaranjem Ozeki SMS Gatewaya, a dovršavanjem svih koraka, imat ćete SMS poruku koja čeka na slanje u odloženoj mapi. Ovaj 1:44 dug video je lako razumljiv i jasno prikazuje sve korake. Koristit ćete Ozeki SMS Gateway nadzornu ploču koja vam omogućuje pristup najvažnijim funkcijama jednim klikom. Naučit ćete kako pokrenuti Ozeki SMS Gateway i kako provjeriti mapu za slanje. Kako pokrenuti kod i kako navesti vrijeme slanja SMS-a.

Video 2 - Slanje planiranog SMS-a s gore navedenim C++ kodom (Video tutorijal)

Sažetak

Glavna funkcija ovog članka bila je objasniti kako zakazati SMS u C/C++ s HTTP SMS API korisnikom Ozeki SMS Gatewaya. Ako ste pažljivo pročitali vodič, zakazivanje SMS-a s C/C++ trebalo bi biti vrlo jednostavno. Dijeljenje informacija u savršenom trenutku ključno je za najučinkovitiji rad jer na taj način možete smanjiti promet SMS-ova i kontaktirati svoje kolege kada su spremni za čitanje poruka.

Svakako nastavite čitati upute na Ozeki web stranici za više informacija. Zaronite u druge C/C++ tutorijale poput Kako primiti SMS u C/C++ i više.

Sada preuzmite Ozeki SMS Gateway i neka počne rad!

More information