Kako zakazati SMS u Pythonu

Najjednostavniji način za slanje zakazanih SMS poruka iz Pythona 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 zakazati sms u pythonu
Slika 1 - Kako zakazati SMS u Pythonu

Python kod za slanje zakazanog sms-a na mobilni telefon

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

SendScheduledSms.py

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
from ozekilibsrest import Configuration, Message, MessageApi
from datetime import datetime
         
configuration = Configuration(
    username="http_user",
    password="qwe123",
    api_url="http://127.0.0.1:9509/api"
)
         
msg = Message(
    to_address="+3620111111",
    text="Hello world!",
    time_to_send=datetime.strptime("2021-09-10 14:25:00", "%Y-%m-%d %H:%M:%S")
)
         
api = MessageApi(configuration)
         
result = api.send(msg)
         
print(result)
     

Kako koristiti Python sms primjer:

Ovaj Python sms primjer može se koristiti u bilo kojoj Python aplikaciji. Da biste ga koristili, morate instalirati ozekilibsrest paket naredbom pip install ozekilibsrest. Nakon što je paket instaliran, morate dodati from ozekilibsrest import Configuration, Message, MessageApi u zaglavlje vašeg Python izvornog koda. To će vam omogućiti korištenje klasa koje pruža ozekilibsrest biblioteka. Možete koristiti klasu Message za kreiranje SMS-a. Možete koristiti klasu MessageApi za slanje SMS-a SMS gatewayu. SMS gateway će proslijediti vašu poruku mobilnoj mreži bilo putem bežične veze ili putem interneta.

Preuzmite SendScheduledSms.py

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

Što se nalazi u mapi SendScheduledSms.py?

Mapa SendScheduledSms.py sadrži skriptu python sms primjera koja će vam pokazati kako poslati zakazane SMS poruke koristeći Python.

mapa send scheduled sms py
Slika 2 - Što se nalazi unutar SendScheduledSms.py.zip

Kako instalirati ozekilibsrest biblioteku

Da biste instalirali ozekilibsrest biblioteku, morate otvoriti komandnu liniju i koristiti sljedeću naredbu. Ovo će instalirati ozekilibsrest biblioteku i ovisnosti koje su joj potrebne.

1
2
pip install ozekilibsrest
     

Kod 2 - Naredba za instalaciju ozekilibsrest biblioteke

Kako poslati zakazani sms iz Pythona (Brzi koraci)

Da biste poslali zakazani sms iz Pythona:

  1. Preuzmite i instalirajte Python
  2. Instalirajte ozekilibsrest biblioteku koristeći pip ili codna
  3. Preuzmite datoteku SendScheduledSms.py.zip
  4. Ekstrahirajte .zip datoteku iz mape Preuzimanja
  5. Otvorite datoteku SendScheduledSms.py u bilo kojem tekstualnom editoru
  6. Pokrenite Ozeki SMS Gateway
  7. Kreirajte HTTP API korisnika u Ozekiju
  8. Pokrenite SendScheduledSms.py kod koristeći komandnu liniju za slanje testnih SMS poruka
  9. Provjerite Sent kutiju u Ozeki SMS Gatewayu

Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika

Da biste mogli slati SMS iz Pythona, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu na kojem razvijate svoj Python kod. 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 korisničkog računa. Kreirajte korisnika s korisničkim imenom "http_user" i lozinkom "qwe123" kako bi primjer radio bez modifikacija.

Nakon što je okruženje postavljeno, možete pokrenuti svoj Python kod.

HTTP API url za slanje sms-a iz Pythona

Da biste poslali SMS iz Pythona, vaš Python ć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 Python 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-a iz Pythona

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

1
2
3
4
def create_authorization_header(username, password):
    username_password = f'{ username }:{ password }'
    return f'Basic { b64encode(username_password.encode()).decode() }'
     

Na primjer, ako enkodirate korisničko ime 'http_user' i lozinku 'qwe123', dobit ćete sljedeći base64 kodirani string: aHR0cF91c2VyOnF3ZTEyMw==.

HTTP zaglavlje zahtjeva za slanje SMS-a iz Pythona

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.

1
2
3
Content-Type: application/json
Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
     

HTTP zahtjev za slanje SMS-a iz Pythona

Za slanje SMS poruka, vaša Python aplikacija će poslati HTTP zahtjev sličan donjem. 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 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
POST /api?action=sendmsg HTTP/1.1
Host: 127.0.0.1:9509
User-Agent: python-requests/2.26.0
Accept-Encoding: gzip, deflate
Accept: */*
Connection: keep-alive
Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw==
Content-Type: application/json
Content-Length: 349
 
{
    "messages": [
        {
            "message_id": "cd0067bf-0797-489e-8796-325dacc68552",
            "to_address": "+3620111111",
            "text": "Hello world!",
            "create_date": "2021-09-17T08:20:15",
            "valid_until": "2021-09-24T08:20:15",
            "time_to_send": "2021-09-17T08:25:00",
            "submit_report_requested": true,
            "delivery_report_requested": true,
            "view_report_requested": true,
            "tags": []
        }
    ]
}
     

HTTP odgovor primljen od Python SMS primjera

Nakon što SMS gateway primi ovaj zahtjev, generirat će HTTP odgovor. HTTP odgovor će sadržavati statusni kod, koji označava je li zahtjev za slanje SMS-a uspješan ili ne. Također će vratiti JSON kodiranu strukturu koja vam pruža 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
HTTP/1.1 200 OK
Transfer-Encoding: chunked
Content-Type: application/json; charset=utf8
Last-Modified: Thu, 16 Sep 2021 09:14:44 GMT
Server: 10/10.3.124 Microsoft-HTTPAPI/2.0
User-Agent: OZEKI 10.3.124 (www.myozeki.com)
Access-Control-Allow-Origin: *
Date: Fri, 17 Sep 2021 06:20:15 GMT
 
{
  "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": "cd0067bf-0797-489e-8796-325dacc68552",
        "from_station": "%",
        "to_address": "+3620111111",
        "to_station": "%",
        "text": "Hello world!",
        "create_date": "2021-09-17 08:20:15",
        "valid_until": "2021-09-24 08:20:15",
        "time_to_send": "2021-09-17 08:25:00",
        "submit_report_requested": true,
        "delivery_report_requested": true,
        "view_report_requested": false,
        "tags": [
          {
            "name": "Type",
            "value": "SMS:TEXT"
          }
        ],
        "status": "SUCCESS"
      }
    ]
  }
}
     

Python SMS primjer: SendScheduledSms.py

Kako preuzeti projekt SendScheduledSMS.py (Video tutorial)

U sljedećem videu naučit ćete kako možete koristiti SendScheduledSms.py Python projekt. Video će započeti sa stranicom za preuzimanje i odvesti vas sve do otvorenog panela urednika koda. Naučit ćete kako preuzeti i otvoriti datoteku koda. Video traje samo 54 sekunde, ali sadrži sve potrebne informacije za uspješno korištenje primjera koda.

Video 1 - Kako preuzeti i otvoriti rješenje iznad (Video tutorial)

Primjer koda u nastavku dio je SendScheduledSms.py.zip mape.

Slika 3 - SendScheduledSms.py

Kako koristiti projekt (Video tutorial)

U sljedećem isječku vidjet ćete kako možete pokrenuti SendScheduledSms.py Python kod. Video će započeti s otvorenim kodom i odvesti vas sve do kartice događaja s logom poslane poruke. Vidjet ćete kako pokrenuti kod i što se dogodilo ako je kod izvršen. Video je nešto kraći od 1 minute, ali sadrži sve informacije potrebne za pokretanje projekta.

Video 2 - Kako koristiti SendScheduledSms.py skriptu (Video tutorial)

Zaključak

Ovaj članak je pokazao korake planiranog slanja SMS-ova u jednom zahtjevu iz Pythona.

S ovim znanjem i pruženim alatima, trebali biste biti u mogućnosti kontaktirati više korisnika s jednim jedinim kodom. Ozeki SMS Gateway ima važnu ulogu u ovom procesu jer ovaj program organizira isporuku poruka. Ozeki SMS Gateway radi s visokom kvalitetom i performansama, omogućujući vam slanje do 1000 SMS-ova u sekundi.

Nastavite svoje učenje na Ozeki-jevim stranicama s tutorijalima, gdje možete pročitati o temama kao što su Primanje SMS-ova u Pythonu.

Sada vam preostaje samo preuzeti Ozeki SMS Gateway i početi raditi!

More information