Kako zakazati SMS u Javi
Najjednostavniji način za slanje SMS-a iz Jave 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 vratit će HTTP 200 OK odgovor na vaš zahtjev.
Java kod za slanje sms-a na mobilni telefon
Java sms primjer koda ispod pokazuje kako možete poslati SMS koristeći http rest sms api Ozeki SMS Gatewaya koristeći Java Ozeki.Libs.Rest biblioteku. Ova biblioteka vam je dostupna besplatno i možete je koristiti i mijenjati u bilo kojem od vaših projekata.
Main.javaimport Ozeki.Libs.Rest.*; import java.time.LocalDateTime; public class Main { public static void main(String[] args) { var configuration = new Configuration(); configuration.Username = "http_user"; configuration.Password = "qwe123"; configuration.ApiURL = "http://127.0.0.1:9509/api"; var msg = new Message(); msg.ToAddress = "+36201111111"; msg.Text = "Hello world!"; msg.TimeToSend = LocalDateTime.parse("2021-06-11T13:52:00"); var api = new MessageApi(configuration); var result = api.Send(msg); System.out.println(result); } }
Kako koristiti Java sms primjer:
Možete koristiti klasu Message za kreiranje SMS-a i 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.java
Izvorni kod objašnjen u ovom članku može se preuzeti, koristiti i mijenjati besplatno.
Preuzimanje: SendScheduledSms.java.zip (80.2Kb)
Što se nalazi u SendScheduledSms.java.zip datoteci?
SendScheduledSms.java.zip datoteka sadrži Ozeki biblioteku, koja vam daje sve potrebne alate za slanje i primanje SMS poruka. Također ćete pronaći Main.java datoteku u projektu, koja sadrži primjer koda koji vam pokazuje kako poslati SMS. Ovaj primjer koda je naveden ispod.
Kako poslati zakazani SMS iz Jave (Brzi koraci)
Za slanje zakazanog sms-a iz Jave:
- Instalirajte Ozeki SMS Gateway
- Povežite Ozeki SMS Gateway s mobilnom mrežom
- Pošaljete testni sms iz Ozeki GUI
- Kreirajte HTTP sms api korisnika
- Apache NetBeans
- Kreirajte projekt pod nazivom SendScheduledSms
- Stavite kod u novokreiranu Main.java datoteku ili koristite Main.java datoteku u .zip datoteci
- Kreirajte SMS kreiranjem novog Message objekta
- Kreirajte api za slanje vaše poruke
- Koristite metodu Send za slanje vaše poruke
- Navedite atribut TimeToSend novokreirane poruke
- Pročitajte odgovor poruke na konzoli
- Provjerite zapise u SMS gatewayu
Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika
Da biste mogli slati SMS iz Jave, prvo morate 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 Java kod.
HTTP API url za slanje sms-a iz Jave
Za slanje SMS-a iz Jave, vaša Java aplikacija ć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 gdje se pokreće Java 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 Jave
Za autentifikaciju Java sms klijenta, 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 Javi možete koristiti sljedeći kod za ovo kodiranje:
var usernamePassword = username + ":" + password; var encodedUsernamePassword = usernamePassword.getBytes(); return "Basic " + Base64.getEncoder().encodeToString(encodedUsernamePassword);
Na primjer, ako kodirate korisničko ime 'http_user' i lozinku 'qwe123', dobit ćete sljedeći base64 kodirani string: aHR0cF91c2VyOnF3ZTEyMw==. Za slanje
HTTP zaglavlje zahtjeva za slanje planirane SMS poruke iz Jave
Za slanje planirane SMS poruke, potrebno je uključiti sljedeće retke kao zaglavlja u HTTP zahtjev. Imajte na umu da uključujemo vrstu sadržaja (content type) i zaglavlje za autorizaciju (Authorization).
Content-Type: application/json Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
HTTP zahtjev za slanje SMS-a iz Jave
Za slanje SMS-a, vaša Java aplikacija će poslati HTTP zahtjev sličan donjem primjeru. Imajte na umu da ovaj zahtjev sadrži dio HTTP zaglavlja i dio HTTP tijela. HTTP tijelo je JSON kodirani niz podataka. Sadrži broj primatelja i tekst poruke.
POST /api?action=sendmsg HTTP/1.1 HTTP2-Settings: AAEAAEAAAAIAAAABAAMAAABkAAQBAAAAAAUAAEAA Connection: Upgrade, HTTP2-Settings Upgrade: h2c Content-Length: 320 Content-Type: application/json Accept: application/json Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw== Host: 127.0.0.1:9509 User-Agent: Java-http-client/16.0.1 { "messages": [ { "message_id": "5b9cea01-6bc0-42a7-9409-7b86eedf851b", "submit_report_requested": true, "view_report_requested": true, "valid_until": "2021-06-18 13:49:36", "time_to_send": "2021-06-11 13:52:00", "to_address": "+36201111111", "text": "Hello world!", "create_date": "2021-06-11 13:49:36", "delivery_report_requested": true } ] }
HTTP odgovor primljen u Java 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 poruka.
HTTP/1.1 200 OK User-Agent: OZEKI 10.3.120 (www.myozeki.com) Content-Type: application/json; charset=utf8 Last-Modified: Fri, 11 Jun 2021 13:37:11 GMT Server: 10/10.3.120 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": "5b9cea01-6bc0-42a7-9409-7b86eedf851b", "from_station": "%", "to_address": "+36201111111", "to_station": "%", "text": "Hello world!", "create_date": "2021-06-11 13:49:36", "valid_until": "2021-06-18 13:49:36", "time_to_send": "2021-06-11 13:52:00", "submit_report_requested": true, "delivery_report_requested": true, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" } ] } }
Kako poslati SMS iz Jave koristeći Java SMS API (Video tutorijal)
Ovaj video vam pokazuje kako stvoriti novi projekt u Apache NetBeans, kako ga nazvati SendScheduledSms. Nakon što je projekt stvoren, možete primijetiti da postoji mapa pod nazivom <default package> u vašem projektu unutar mape Source Packages. Ovdje ćete kreirati ili zalijepiti datoteku Main.java. Zatim morate zalijepiti mapu Ozeki u mapu Source Packages i to su sve pripreme koje su vam potrebne za slanje SMS-a koristeći Javu.
Java kod za slanje SMS-a na mobilni telefon
Java SMS primjer koda ispod pokazuje kako možete poslati SMS koristeći http rest SMS API Ozeki SMS Gatewaya koristeći Java Ozeki.Libs.Rest biblioteku. Ova biblioteka vam je dostupna besplatno, a možete je koristiti i mijenjati u bilo kojem od vaših projekata.
Main.javaimport Ozeki.Libs.Rest.*; import java.time.LocalDateTime; public class Main { public static void main(String[] args) { var configuration = new Configuration(); configuration.Username = "http_user"; configuration.Password = "qwe123"; configuration.ApiURL = "http://127.0.0.1:9509/api"; var msg = new Message(); msg.ToAddress = "+36201111111"; msg.Text = "Hello world!"; msg.TimeToSend = LocalDateTime.parse("2021-06-11T13:52:00"); var api = new MessageApi(configuration); var result = api.Send(msg); System.out.println(result); } }
Kako koristiti Java SMS primjer:
Možete koristiti klasu Message za kreiranje SMS-a i 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.
Java SMS primjer: Main.java
Kako provjeriti je li SMS prihvaćen od strane HTTP korisnika
Nakon što je SMS poslan, dobro je provjeriti vaš SMS gateway, kako biste vidjeli što je primio. Dnevnik možete provjeriti otvaranjem detalja HTTP korisnika iz konzole za upravljanje Ozeki SMS Gatewaya. Sljedeći video vam pokazuje što trebate tražiti.
Zaključak
Ovaj članak pružio je uvid u planiranje SMS poruka u Javi pomoću Ozeki SMS Gatewaya. Ako želite slati tekstualne poruke u određeno vrijeme, planiranje SMS poruka može biti vrlo korisno. Korištenjem ovog vodiča i gornjeg koda dobivate sva znanja i alate potrebne za omogućavanje planiranja SMS poruka. Ozeki SMS Gateway omogućuje vam bilježenje poruka u bazu podataka i nudi brojne mogućnosti izvještavanja kako bi vam pružio što više informacija o SMS komunikaciji.
Nastavite čitanje na Ozekijevoj stranici s tutorijalima, gdje možete pronaći više informacija o temama poput primanja u Javi.
Jedino što sada preostaje je preuzeti Ozeki SMS Gateway i početi raditi!
More information