Cum să programezi un SMS în PHP
Cea mai simplă metodă de a trimite SMS din PHP este utilizarea API-ului HTTP/Rest SMS integrat al Ozeki SMS Gateway. Când folosești acest API, vei trimite mesaje SMS prin efectuarea unei cereri HTTP Post către gateway-ul SMS. Cererea HTTP Post va conține un mesaj formatat în format json. Gateway-ul SMS va trimite acest SMS către telefonul destinatar și va returna un răspuns HTTP 200 OK la cererea ta.
Exemplul de cod PHP pentru sms de mai jos demonstrează cum poți trimite SMS folosind API-ul http rest sms al Ozeki SMS Gateway cu ajutorul bibliotecii PHP Ozeki.Libs.Rest. Această bibliotecă este oferită gratuit și poți să o folosești și să o modifici în oricare dintre proiectele tale.
SendSMS.csnamespace Ozeki_PHP_Rest { require 'MessageApi/MessageApi.php'; $configuration = new Configuration(); $configuration -> Username = "http_user"; $configuration -> Password = "qwe123"; $configuration -> ApiUrl = "http://127.0.0.1:9509/api"; $msg = new Message(); $msg -> ToAddress = "+36201111111"; $msg -> Text = "Bună, lume!"; $msg -> TimeToSend = "2021-06-23 16:18:00"; $api = new MessageApi($configuration); $result = $api -> SendSingle($msg); echo strval($result); }
Cum să folosești exemplul PHP pentru sms:
Acest exemplu PHP pentru sms poate fi folosit în orice aplicație PHP. Pentru a-l folosi, trebuie să adaugi folderul MessageApi în proiectul tău. Poți folosi clasa Message pentru a crea SMS-ul și poți folosi clasa MessageApi pentru a trimite SMS-ul către gateway-ul SMS. Gateway-ul SMS va transmite mesajul tău către rețeaua mobilă fie printr-o conexiune wireless, fie prin Internet.
Descarcă Send-schedule-SMS.php
Codul sursă explicat în acest articol poate fi descărcat, folosit și modificat gratuit.
Descarcă: Send-schedule-SMS.zip (5.9Kb)
Fișierul SendSMS.zip conține biblioteca Ozeki.Libs.Rest.Php, care îți oferă toate instrumentele necesare pentru a trimite și primi mesaje SMS. De asemenea, vei găsi proiectul SendScheduleSms în zip, care conține codul exemplu pentru a-ți arăta cum să trimiți un SMS. Acest cod exemplu este listat mai jos.
Pentru a trimite sms din PHP:
- Instalează Ozeki SMS Gateway
- Conectează Ozeki SMS Gateway la rețeaua mobilă
- Trimite un sms de test din Ozeki GUI
- Crează un utilizator HTTP sms api
- Pornește serverul Wamp
- Descarcă exemplul de mai sus
- Creează SMS-ul prin crearea unui nou obiect Message
- Folosește metoda SendSingle pentru a trimite mesajul tău
- Citește răspunsul HTTP
- Verifică logurile din gateway-ul SMS
Pentru a putea trimite SMS din PHP, mai întâi trebuie să instalezi Ozeki SMS Gateway. Gateway-ul SMS poate fi instalat pe același calculator unde dezvolți codul tău PHP. După instalare, următorul pas este să conectezi Ozeki SMS Gateway la rețeaua mobilă. Poți creezi un utilizator HTTP sms api. Creează un utilizator cu numele de utilizator "http_user" și parola "qwe123" pentru a face exemplul să funcționeze fără modificări.
După ce mediul este configurat, poți rula codul tău PHP.
URL API HTTP pentru a trimite SMS din PHPPentru a trimite SMS din PHP, PHP-ul tău va trebui să efectueze o cerere HTTP către gateway-ul SMS. URL-ul API este afișat mai jos. Reține că adresa IP (127.0.0.1) ar trebui să fie înlocuită cu adresa IP a gateway-ului tău SMS. Dacă Ozeki SMS Gateway este instalat pe același calculator unde rulează aplicația C# pentru sms, aceasta poate fi 127.0.0.1. Dacă este instalat pe un alt calculator, ar trebui să fie adresa IP a acelui calculator.
http://127.0.0.1:9509/api?action=rest
Pentru a trimite mesajele SMS, trebuie să incluzi următoarele linii ca antete în cererea HTTP. Reține că includem un antet pentru tipul conținutului și un antet de Autorizare.
Content-Type: application/json Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Cerere HTTP pentru trimiterea SMS din PHP
Pentru a trimite SMS-ul, aplicația ta PHP va trimite o cerere HTTP similară cu cea de mai jos. Reține că această cerere conține o parte de antet HTTP și o parte de corp HTTP. Corpul HTTP este un șir de date codificat în JSON. Acesta conține numărul destinatarului și textul mesajului.
Cerere HTTP primită de la 192.168.0.113:57045 POST /api?action=sendmsg HTTP/1.1 Content-Length: 433 Content-Type: application/json Accept: */* Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw== Host: 192.168.0.113:9509 { "messages": [ { "message_id": "75ce6646-0a84-48d6-996a-02b632eef83a", "from_connection": null, "from_address": null, "from_station": null, "to_connection": null, "to_address": "+36201111111", "to_station": null, "text": "Bună, lume!", "create_date": "2021-06-16 15:48:03", "valid_until": "2021-06-23 15:48:03", "time_to_send": "2021-06-23 16:18:00", "submit_report_requested": true, "delivery_report_requested": true, "view_report_requested": true, "tags": [] } ] }
Răspuns HTTP primit de exemplul PHP pentru SMS
Odată ce gateway-ul SMS primește această cerere, va genera un răspuns HTTP. Răspunsul HTTP va conține un cod de stare, pentru a indica dacă cererea de trimitere a SMS-ului a fost reușită sau nu. De asemenea, va returna o structură codificată în JSON pentru a vă oferi detalii utile despre trimiterea mesajului.
HTTP/1.1 200 OK User-Agent: OZEKI 10.3.118 (www.myozeki.com) Content-Type: application/json; charset=utf8 Last-Modified: Mon, 14 Jun 2021 07:43:45 GMT Server: 10/10.3.118 Transfer-Encoding: chunked { "http_code": 200, "response_code": "SUCCES", "response_msg": "Mesaje puse în coadă pentru livrare.", "data": { "total_count": 1, "success_count": 1, "failed_count": 0, "messages": [ { "message_id": "38585421-3260-4bf9-9daa-2b39ec16961a", "from_station": "%", "to_address": "+36201111111", "to_station": "%", "text": "Bună, lume!", "create_date": "2021-06-16 15:48:03", "valid_until": "2021-06-16 15:48:03", "time_to_send": "2021-06-23 16:18:00", "submit_report_requested": true, "delivery_report_requested": true, "view_report_requested": false, "tags": [ { "name": "Tip", "value": "SMS:TEXT" } ], "status": "SUCCES" } ] } }
Cum să trimiți SMS din PHP folosind API-ul PHP pentru SMS (Tutorial video)
Acest videoclip vă arată cum să descărcați și să folosiți proiectul PHP SendSMS. După ce ați adăugat fișierele necesare în proiectul dvs., s-ar putea să observați că există un fișier numit MessageApi.php. Acesta este fișierul care conține MessageApi și toate elementele necesare pentru a trimite un SMS folosind PHP.
Exemplu PHP SMS: Send_Message.php
Cum să verificați că SMS-ul a fost acceptat de utilizatorul HTTP
După ce SMS-ul a fost trimis, este o idee bună să verificați gateway-ul SMS, pentru a vedea ce a primit. Puteți verifica jurnalul deschizând detaliile utilizatorului HTTP din consola de management Ozeki SMS Gateway. Următorul videoclip vă arată ce să căutați.
Cum să verificați că SMS-ul a fost trimis către rețeaua mobilă
Pasul final în verificarea procedurii este să aruncați o privire asupra jurnalelor conexiunii la rețeaua mobilă. S-ar putea să fie nevoie să activați jurnalizarea în configurația conexiunii înainte de a trimite mesajul pentru a vedea jurnalele. Dacă jurnalizarea este activată, veți vedea numărul de telefon și textul mesajului pe care l-ați trimis.
Pentru a rezuma
Din acest ghid, puteți obține cunoștințele necesare pentru a trimite SMS-uri programate cu API-ul HTTP REST SMS al Ozeki SMS Gateway din PHP. Folosirea acestui API PHP pentru SMS vă ajută să respectați programul și să vă conduceți afacerea mult mai profesional. Acest serviciu este ușor de configurat, vine cu codul sursă complet și îl puteți folosi și modifica fără nicio limitare.
Informațiile pe care le-ați obținut sunt valoroase, hai să adunăm mai multe! Ozeki are multe alte articole care vă pot ajuta, continuați cu tutorialul GitHub PHP SMS API.
Acum, următorul lucru pe care trebuie să-l faceți este să descărcați Ozeki SMS Gateway și să configurați această soluție imediat!
More information
- PHP send SMS with the HTTP rest API (code sample)
- PHP send multiple SMS with the HTTP rest API (code sample)
- PHP schedule SMS with the HTTP rest API (code sample)
- PHP receive SMS with the HTTP rest API (code sample)
- PHP delete SMS with the HTTP rest API (code sample)
- Github: PHP SMS API