Kako poslati više SMS poruka iz Python flask-a

Najjednostavniji način za slanje SMS poruka iz Python flask-a je korištenje ugrađenog HTTP/Rest SMS API-ja Ozeki SMS Gateway-a. Kada koristite ovaj API, slati ćete SMS poruke tako što ćete poslati HTTP Post zahtjev SMS gateway-u. HTTP Post zahtjev će sadržavati poruku formatiranu u json formatu. SMS gateway će poslati ovu SMS poruku na telefon primatelja i vratit će HTTP 200 OK odgovor na vaš zahtjev.

kako poslati više SMS poruka iz Python flask-a
Slika 1 - Kako poslati više SMS poruka iz Python flask-a

Python kod za slanje SMS poruka na mobilni telefon

Python SMS kod primjer ispod pokazuje kako možete poslati SMS koristeći http rest SMS API Ozeki SMS Gateway-a koristeći Python ozekilibsrest biblioteku. Ova biblioteka vam je dostupna besplatno i možete je koristiti i mijenjati u bilo kojem od vaših projekata.

SendMultipleSms.py

		from flask import Flask, render_template, request
		from ozekilibsrest import Configuration, Message, MessageApi
		
		app = Flask(__name__)
		
		configuration = Configuration(
		    username="http_user",
		    password="qwe123",
		    api_url="http://127.0.0.1:9509/api"
		)
		
		api = MessageApi(configuration)
		
		messages_to_send = []
		logs = []
		
		
		@app.route('/', methods=['GET', 'POST'])
		def index():
		    if request.method == 'POST':
		        if request.form['submit'] == 'SEND' and len(messages_to_send) > 0:
		            log = api.send(messages_to_send)
		            logs.append(log)
		            messages_to_send.clear()
		        elif request.form['submit'] == 'ADD':
		            message = Message(
		                to_address=request.form['to_address'],
		                text=request.form['text']
		            )
		            messages_to_send.append(message)
		    return render_template('SendMultipleSms.html', logs=logs, messages=messages_to_send)
		
		
		if __name__ == '__main__':
		    app.run()
	

Kod 1 - SendMultipleSms.py

SendMultipleSms.html

		<!DOCTYPE html>
		<html lang="en">
		    <head>
		        <meta charset="UTF-8">
		        <title>Send multiple SMS with Ozeki SMS Gateway</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: 8vh; margin-left: 30%;
		        display: flex; flex-direction: column; height: 30vh;
		        justify-content: space-evenly;">
		            <b>To address:</b>
		            <input class="form-control" type="text"
		                   name="to_address" placeholder="+36201111111"
		                   autocomplete=false>
		            <b>Text:</b>
		            <input class="form-control"
		                   type="text" name="text"
		                   placeholder="Hello world!"
		                   autocomplete=false>
		            <input class="btn btn-primary"
		                   style="font-weight: 600;"
		                   type="submit"
		                   name="submit"
		                   value="ADD">
		        </form>
		        <ul style="width: 40%; margin-left: 30%;
		        margin-bottom: 30px; height: 20vh; overflow-y: scroll;"
		            class="list-group card">
		            <li class="list-group-item card"><b>Messages:</b></li>
		            {% if messages %}
		                {%for message in messages%}
		                    <li class="list-group-item">{{ message }}</li>
		                {%endfor%}
		            {% endif  %}
		        </ul>
		        <form method="POST" class="form-group"
		        style="width: 40%; margin-left: 30%;
		            display: flex; flex-direction: column;
		            height: auto; justify-content: space-evenly;">
		            <input class="btn btn-primary"
		                   style="font-weight: 600;"
		                   type="submit"
		                   name="submit"
		                   value="SEND">
		        </form>
		        <ul style="width: 40%; margin-left: 30%;
		        margin-top: 30px; height: 20vh;
		        overflow-y: scroll;"
		            class="list-group card">
		            <li class="list-group-item card"><b>Logs:</b></li>
		            {% if logs %}
		                {%for log in logs%}
		                    <li class="list-group-item">{{ log }}</li>
		                {%endfor%}
		            {% endif  %}
		        </ul>
		    </body>
		</html>
	

Kod 2 - SendMultipleSms.html

Kako koristiti Python flask SMS primjer:

Ovaj Python flask SMS primjer može se koristiti u bilo kojoj Python aplikaciji. Da biste ga koristili, morate instalirati ozekilibsrest paket s naredbom pip install ozekilibsrest i flask paket s naredbom pip install flask. Nakon što su paketi instalirani, morate dodati from ozekilibsrest import Configuration, Message, MessageApi direktivu i from flask import Flask, render_template, request 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 poruka. Možete koristiti klasu MessageApi za slanje SMS poruka SMS gateway-u. SMS gateway će proslijediti vašu poruku mobilnoj mreži bilo putem bežične veze ili putem interneta.

Preuzmite SendMultipleSms.py

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

Što se nalazi u mapi SendMultipleSms.py?

Mapa SendMultipleSms.py sadrži skriptu primjera Python flask SMS-a koja će vam pokazati kako poslati više SMS poruka koristeći Python.

send multiple sms py directory
Slika 2 - Što se nalazi unutar SendMultipleSms.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 potrebne ovisnosti.

		pip install ozekilibsrest
	

Kod 3 - Naredba za instalaciju ozekilibsrest biblioteke

Kako instalirati flask biblioteku

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

		pip install flask
	

Kod 2 - Naredba za instalaciju flask biblioteke

Kako poslati više SMS poruka iz Python flaska (Brzi koraci)

Da biste poslali više SMS poruka iz Python flaska:

  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 SendMultipleSms.py.zip
  5. Raspakirajte .zip datoteku iz mape Preuzimanja
  6. Otvorite datoteku SendMultipleSms.py u bilo kojem uređivaču teksta
  7. Pokrenite Ozeki SMS Gateway
  8. Kreirajte HTTP API korisnika u Ozekiju
  9. Pokrenite kod SendMultipleSms.py koristeći komandnu liniju za slanje testnih SMS poruka
  10. Provjerite mapu Poslano 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 gdje 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. 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 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 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 gdje 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.

		http://127.0.0.1:9509/api?action=rest
	

HTTP autentifikacija za slanje SMS-a iz Pythona

Da biste autentificirali Python SMS klijent, 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 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-a iz Pythona

Da biste poslali SMS poruke, morate uključiti sljedeće retke kao zaglavlja u HTTP zahtjevu. Imajte na umu da uključujemo content type i Authorization zaglavlje.

		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 HTTP tijela. HTTP tijelo je JSON kodirani niz podataka. Sadrži brojeve primatelja i tekstove poruka.

		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: 1027
		
		{
			"messages": [
				{
					"message_id": "cf609600-7269-46e3-ab6e-87ef5a99f848",
					"to_address": "+3620111111",
					"text": "Hello world 1!",
					"create_date": "2021-09-10T15:19:20",
					"valid_until": "2021-09-17T15:19:20",
					"time_to_send": "2021-09-10T15:19:20",
					"submit_report_requested": true,
					"delivery_report_requested": true,
					"view_report_requested": true,
					"tags": []
				},
				{
					"message_id": "8d93e43a-b4dc-493f-a243-10db358a58ec",
					"to_address": "+36202222222",
					"text": "Hello world 2!",
					"create_date": "2021-09-10T15:19:20",
					"valid_until": "2021-09-17T15:19:20",
					"time_to_send": "2021-09-10T15:19:20",
					"submit_report_requested": true,
					"delivery_report_requested": true,
					"view_report_requested": true,
					"tags": []
				},
				{
					"message_id": "35e56437-15e4-4ee7-9ad4-dfc00a8f7c3a",
					"to_address": "+36203333333",
					"text": "Hello world 3!",
					"create_date": "2021-09-10T15:19:20",
					"valid_until": "2021-09-17T15:19:20",
					"time_to_send": "2021-09-10T15:19:20",
					"submit_report_requested": true,
					"delivery_report_requested": true,
					"view_report_requested": true,
					"tags": []
				}
			]
		}
	

HTTP odgovor primljen u Python 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 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
		Transfer-Encoding: chunked
		Content-Type: application/json; charset=utf8
		Last-Modified: Fri, 10 Sep 2021 10:22:37 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, 10 Sep 2021 13:19:19 GMT
		
		{
		  "http_code": 200,
		  "response_code": "SUCCESS",
		  "response_msg": "Poruke su u redu čekanja za isporuku.",
		  "data": {
		    "total_count": 3,
		    "success_count": 3,
		    "failed_count": 0,
		    "messages": [
		      {
		        "message_id": "cf609600-7269-46e3-ab6e-87ef5a99f848",
		        "from_station": "%",
		        "to_address": "+3620111111",
		        "to_station": "%",
		        "text": "Hello world 1!",
		        "create_date": "2021-09-10 15:19:20",
		        "valid_until": "2021-09-17 15:19:20",
		        "time_to_send": "2021-09-10 15:19:20",
		        "submit_report_requested": true,
		        "delivery_report_requested": true,
		        "view_report_requested": false,
		        "tags": [
		          {
		            "name": "Type",
		            "value": "SMS:TEXT"
		          }
		        ],
		        "status": "SUCCESS"
		      },
		      {
		        "message_id": "8d93e43a-b4dc-493f-a243-10db358a58ec",
		        "from_station": "%",
		        "to_address": "+36202222222",
		        "to_station": "%",
		        "text": "Hello world 2!",
		        "create_date": "2021-09-10 15:19:20",
		        "valid_until": "2021-09-17 15:19:20",
		        "time_to_send": "2021-09-10 15:19:20",
		        "submit_report_requested": true,
		        "delivery_report_requested": true,
		        "view_report_requested": false,
		        "tags": [
		          {
		            "name": "Type",
		            "value": "SMS:TEXT"
		          }
		        ],
		        "status": "SUCCESS"
		      },
		      {
		        "message_id": "35e56437-15e4-4ee7-9ad4-dfc00a8f7c3a",
		        "from_station": "%",
		        "to_address": "+36203333333",
		        "to_station": "%",
		        "text": "Hello world 3!",
		        "create_date": "2021-09-10 15:19:20",
		        "valid_until": "2021-09-17 15:19:20",
		        "time_to_send": "2021-09-10 15:19:20",
		        "submit_report_requested": true,
		        "delivery_report_requested": true,
		        "view_report_requested": false,
		        "tags": [
		          {
		            "name": "Type",
		            "value": "SMS:TEXT"
		          }
		        ],
		        "status": "SUCCESS"
		      }
		    ]
		  }
		}
	

Python SMS primjer: SendMultipleSms.py

Kako preuzeti projekt SendMultipleSMS.py (Video tutorial)

U sljedećem videu naučit ćete kako možete koristiti Python projekt SendMultipleSms.py. 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 koje su vam potrebne za uspješno korištenje primjer datoteke s kodom.

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

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

kako poslati više SMS-ova koristeći Python
Slika 3 - SendMultipleSms.py

Da biste poslali SMS s gornjim primjerom projekta, morate pokrenuti Python skriptu koristeći naredbu python SendSms.py. Nakon što se skripta pokrene, primijetit ćete da naredbeni redak kaže da morate otvoriti http://127.0.0.1:5000 URL. Tamo možete vidjeti svoj prvi Python flask projekt, koji je u mogućnosti poslati više SMS poruka na Ozeki SMS Gateway.

izlaz Python skripte
Slika 4 - Izlaz Python skripte SendMultipleSms.py

rezultat Python skripte
Slika 5 - SendMultipleSms.html web stranica

Kako koristiti projekt (Video tutorial)

U sljedećem isječku vidjet ćete kako možete pokrenuti Python kod SendMultipleSms.py. 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 koje su potrebne za pokretanje projekta.

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

Zaključak

Ovaj članak pokazao je korake slanja više SMS-ova 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 kao što su brisanje u Pythonu.

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

More information