Kako primiti SMS u Python flasku

Najjednostavniji način za primanje SMS-a u Pythonu je korištenje ugrađenog HTTP/Rest SMS API-ja Ozeki SMS Gatewaya. Kada koristite ovaj API, primat ćete SMS poruke slanjem HTTP GET zahtjeva prema SMS gatewayu. HTTP Post odgovor će sadržavati poruke formatirane u JSON formatu. SMS gateway će poslati SMS poruke u Python konzolnu aplikaciju, a ona će vratiti HTTP 200 OK odgovor na vaš zahtjev.

kako primiti sms u python flasku
Slika 1 - Kako primiti SMS u Python flasku

Python kod za primanje SMS-a

Python SMS primjer koda ispod pokazuje kako možete primati SMS koristeći HTTP REST SMS API Ozeki SMS Gatewaya s Python ozekilibsrest bibliotekom. Ova biblioteka vam je dostupna besplatno, a možete je koristiti i mijenjati u bilo kojem od vaših projekata.

ReceiveSms.py

		from flask import Flask, render_template, request
		from ozekilibsrest import Configuration, MessageApi
		app = Flask(__name__)
		
		configuration = Configuration(
		    username="http_user",
		    password="qwe123",
		    api_url="http://127.0.0.1:9509/api"
		)
		
		api = MessageApi(configuration)
		
		logs = []
		
		
		@app.route('/', methods=['GET', 'POST'])
		def index():
		    if request.method == 'POST':
		        messages = api.download_incoming()
		        message_count_string  = messages.__str__()
		        logs.append(message_count_string)
		        for message in messages.messages:
		            message_string = message.__str__()
		            logs.append(message_string)
		    return render_template('ReceiveSms.html', logs=logs)
		
		
		if __name__ == '__main__':
		    app.run()
	

Kod 1 - ReceiveSms.py

ReceiveSms.html

		<!DOCTYPE html>
		<html lang="en">
		    <head>
		        <meta charset="UTF-8">
		        <title>Primanje SMS-a s Ozeki SMS Gatewayom</title>
		        <link rel="stylesheet"
		        href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css"
		        integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T"
		        crossorigin="anonymous">
		    </head>
		    <body>
		        <form action="/" method="POST" class="form-group" style="width: 40%;
		        margin-top: 10vh; margin-left: 30%;
	            display: flex; flex-direction: column;
	            height: 10vh; justify-content: space-evenly;">
		            <button class="btn btn-primary" style="font-weight: 600;"
		                   type="submit" name="submit" value="download">Preuzmi</button>
		        </form>
		        <ul style="width: 40%; margin-left: 30%; height: 70vh; overflow-y: scroll;"
		            class="list-group card">
		            <li class="list-group-item card"><b>Dnevnici:</b></li>
		            {% if logs %}
		                {% for log in logs %}
		                    <li class="list-group-item">{{ log }}</li>
		                {% endfor %}
		            {% endif %}
		        </ul>
		    </body>
		</html>
	

Kod 2 - ReceiveSms.html

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 nudi ozekilibsrest biblioteka. Možete koristiti klasu Message za kreiranje SMS-a. Možete koristiti klasu MessageApi za slanje SMS-a prema SMS gatewayu. SMS gateway će proslijediti vašu poruku mobilnoj mreži bilo putem bežične veze ili putem interneta.

Preuzmite ReceiveSms.py

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

Što se nalazi u mapi ReceiveSms.py?

Mapa ReceiveSms.py sadrži skriptu Python SMS primjera koja će vam pokazati kako primati SMS poruke koristeći Python.

direktorij za primanje sms-a u pythonu
Slika 2 - Što se nalazi u ReceiveSms.py.zip

Kako instalirati ozekilibsrest biblioteku

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

		pip install ozekilibsrest
	

Kod 3 - Naredba za instalaciju ozekilibsrest biblioteke

Kako instalirati flask biblioteku

Da biste instalirali flask biblioteku, morate otvoriti naredbeni redak i koristiti sljedeću naredbu. Ovo će instalirati flask biblioteku i ovisnosti koje su joj potrebne.

		pip install flask
	

Kod 4 - Naredba za instalaciju flask biblioteke

Kako primiti SMS u Pythonu (Brzi koraci)

Da biste primili SMS u Pythonu:

  1. Preuzmite i instalirajte Python
  2. Instalirajte ozekilibsrest biblioteku koristeći pip ili codna
  3. Instalirajte flask biblioteku koristeći pip ili codna
  4. Preuzmite datoteku ReceiveSms.py.zip
  5. Raspakirajte .zip datoteku iz mape Preuzimanja
  6. Otvorite datoteku ReceiveSms.py u bilo kojem uređivaču teksta
  7. Pokrenite Ozeki SMS Gateway
  8. Kreirajte HTTP API korisnika u Ozekiju
  9. Pokrenite kod ReceiveSms.py koristeći naredbeni redak za slanje testnih SMS poruka
  10. Provjerite Poslano sanduče u Ozeki SMS Gatewayu

Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika

Da biste mogli slati SMS poruke iz Python flask aplikacije, 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 testnu SMS poruku iz Ozeki sučelja kako biste potvrdili da vaša mobilna mrežna veza radi. Posljednji korak za pripremu 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 Python kod.

HTTP API URL za slanje SMS poruka iz Python flask aplikacije

Za slanje SMS poruka iz Python flask aplikacije, vaš Python kod mora poslati HTTP zahtjev SMS gatewayu. API URL je prikazan u nastavku. 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 radi Python flask SMS aplikacija, 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 poruka iz Python flask aplikacije

Za autentifikaciju Python flask SMS klijenta, potrebno je 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 Pythonu možete koristiti sljedeći kod za to kodiranje:

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

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

HTTP zaglavlje zahtjeva za slanje SMS poruka iz Python flask aplikacije

Za slanje SMS poruka, potrebno je uključiti sljedeće linije 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 SMS poruka iz Python flask aplikacije

Za slanje SMS poruka, vaša Python flask aplikacija će poslati HTTP zahtjev sličan onome u nastavku. Imajte na umu da ovaj zahtjev sadrži dio HTTP zaglavlja, u zaglavlju smo definirali mapu iz koje želimo preuzeti poruke i akciju. Također smo poslali base64 kodirano korisničko ime i lozinku za autentifikaciju zahtjeva.

GET /api?action=receivemsg&folder=inbox 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==
	

HTTP odgovor primljen od Python flask 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 poruke uspio ili ne. Također će vratiti JSON kodiranu strukturu koja vam pruža korisne pojedinosti o slanju poruke.

HTTP/1.1 200 OK
Transfer-Encoding: chunked
Content-Type: application/json; charset=utf8
Last-Modified: Fri, 17 Sep 2021 08:36:07 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 07:08:11 GMT

{
  "http_code": 200,
  "response_code": "SUCCESS",
  "response_msg": "",
  "data": {
    "folder": "inbox",
    "limit": "1000",
    "data": [
      {
        "message_id": "31bc2fe0-c2a6-4ebe-afcd-6bcd9ea341fb",
        "from_connection": "admin@localhost",
        "from_address": "",
        "from_station": "%",
        "to_connection": "http_user@localhost",
        "to_address": "http_user",
        "to_station": "%",
        "text": "Hello world 1!",
        "create_date": "2021-09-17 09:07:14",
        "valid_until": "2021-09-24 09:07:14",
        "time_to_send": "2021-09-17 09:07:14",
        "submit_report_requested": true,
        "delivery_report_requested": false,
        "view_report_requested": false,
        "tags": []
      },
      {
        "message_id": "b7b8d592-e182-4e96-a375-b4a6aa73e483",
        "from_connection": "admin@localhost",
        "from_address": "",
        "from_station": "%",
        "to_connection": "http_user@localhost",
        "to_address": "http_user",
        "to_station": "%",
        "text": "Hello world 2!",
        "create_date": "2021-09-17 09:07:23",
        "valid_until": "2021-09-24 09:07:23",
        "time_to_send": "2021-09-17 09:07:23",
        "submit_report_requested": true,
        "delivery_report_requested": false,
        "view_report_requested": false,
        "tags": []
      },
      {
        "message_id": "b0308970-a3c9-45c4-bf97-14a914a66f57",
        "from_connection": "admin@localhost",
        "from_address": "",
        "from_station": "%",
        "to_connection": "http_user@localhost",
        "to_address": "http_user",
        "to_station": "%",
        "text": "Hello world 3!",
        "create_date": "2021-09-17 09:07:33",
        "valid_until": "2021-09-24 09:07:33",
        "time_to_send": "2021-09-17 09:07:33",
        "submit_report_requested": true,
        "delivery_report_requested": false,
        "view_report_requested": false,
        "tags": []
      }
    ]
  }
}	
	

Python flask SMS primjer: ReceiveSms.py

Kako preuzeti projekt ReceiveSMS.py (Video tutorial)

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

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

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

Slika 3 - ReceiveSms.py

Slika 4 - Pokretanje Python flask primjera aplikacije u naredbenom retku

Slika 5 - Rezultat gornjeg Python koda

Kako koristiti projekt (Video tutorial)

U sljedećem isječku vidjet ćete kako možete pokrenuti ReceiveSms.py Python kod. Video će započeti s otvorenim kodom i vodit će vas sve do kartice događaja s zapisom 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 ReceiveSms.py skriptu (Video tutorial)

Zaključak

Ovaj članak pokazao je korake primanja SMS-a u jednom zahtjevu iz Python flaska.

S ovim znanjem i pruženim alatima trebali biste biti u mogućnosti obratiti se nekoliko 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 Ozekijevim stranicama s tutorijalima, gdje možete pročitati o temama poput brisanja SMS-ova u Python flasku.

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

More information