Kako izbrisati SMS u Rubyju
Najjednostavniji način za brisanje SMS poruka iz Rubyja 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 na telefon primatelja i vratit će HTTP 200 OK odgovor na vaš zahtjev.
Ruby kod za brisanje SMS poruka
Ruby SMS primjer koda ispod pokazuje kako možete poslati zakazani SMS koristeći http rest SMS API Ozeki SMS Gatewaya koristeći Ruby ozeki_libs_rest gem. Ova knjižnica vam je dostupna besplatno i možete je koristiti i modificirati u bilo kojem od vaših projekata.
DeleteSms.rbrequire 'ozeki_libs_rest' configuration = Configuration.new( "http_user", "qwe123", "http://127.0.0.1:9509/api" ); msg = Message.new msg.id = "f53efb1a-8ff6-4e62-97c3-2c1e81964b9d" api = MessageApi.new(configuration) result = api.delete(Folder.new.inbox, msg) print(result)
Preuzmi DeleteSms.rb
Izvorni kod objašnjen u ovom članku može se preuzeti, koristiti i modificirati besplatno.
Preuzmi: DeleteSms.rb.zip (319B)
Što je u DeleteSms.rb.zip datoteci?
DeleteSms.rb.zip sadrži datoteku DeleteSms.rb, koja sadrži primjer koda koji vam pokazuje kako poslati SMS. Ovaj primjer koda je naveden ispod.
Kako izbrisati SMS koristeći Ruby (Brzi koraci)
Da biste izbrisali SMS koristeći Ruby:
- Preuzmite datoteku DeleteSms.rb.zip
- Ekstrahirajte .zip datoteku iz mape Preuzimanja
- Otvorite datoteku DeleteSms.rb u bilo kojem tekstualnom editoru poput Windows Notepada
- Pokrenite Ozeki SMS Gateway
- Kreirajte HTTP API korisnika u Ozekiju
- Pokrenite DeleteSms.rb Ruby kod koristeći naredbeni redak
- Provjerite poslane poruke u Ozeki SMS Gatewayu
Instalirajte Ozeki SMS Gateway i kreirajte HTTP API korisnika
Da biste mogli slati SMS iz Rubyja, prvo morate instalirati Ozeki SMS Gateway. SMS gateway se može instalirati na istom računalu gdje razvijate svoj Ruby kod u Visual studiju. Nakon instalacije, sljedeći korak je povezivanje Ozeki SMS Gatewaya na mobilnu mrežu. Možete poslati testni SMS iz Ozeki GUI-ja 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 Ruby kod.
HTTP API URL za slanje SMS-a iz Rubyja
Da biste poslali SMS iz Rubyja, vaš Ruby ć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 Ruby 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 Rubyja
Da biste autentificirali Ruby 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 Rubyju možete koristiti sljedeći kod za ovo kodiranje:
username_password = username + ':' + password username_password_encoded = Base64.encode64(username_password) 'Basic ' + username_password_encoded
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 SMS-a iz Rubyja
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==
Za brisanje poruke, vaša Ruby aplikacija će poslati HTTP zahtjev sličan onome ispod. Imajte na umu da ovaj zahtjev sadrži dio HTTP zaglavlja i dio tijela. Dio tijela sadrži json kodirane ID-ove SMS-ova.
POST /api?action=deletemsg HTTP/1.1 Content-Length: 73 Content-Type: application/json Accept: application/json Accept-Encoding: gzip;q=1.0,deflate;q=0.6,identity;q=0.3 Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw== Host: 127.0.0.1:9509 User-Agent: Faraday v1.5.0 { "folder": "inbox", "message_ids": [ "8ddff323-a0e1-474f-b4b1-58d7fed30009" ] }
HTTP odgovor primljen u Ruby 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 porukama.
User-Agent: OZEKI 10.3.123 (www.myozeki.com) Content-Type: application/json; charset=utf8 Last-Modified: Tue, 06 Jul 2021 15:58:36 GMT Server: 10/10.3.123 Transfer-Encoding: chunked { "http_code": 200, "response_code": "SUCCESS", "response_msg": "", "data": { "folder": "inbox", "message_ids": [ "8ddff323-a0e1-474f-b4b1-58d7fed30009" ] } }
Ruby SMS primjer: DeleteSms.rb
U sljedećem videu vidjet ćete kako preuzeti primjernu datoteku. Ovaj 36-sekundni video je vrlo detaljan i pokazat će svaki važan korak koji trebate poduzeti kako biste imali projektnu datoteku na svom računalu. Nećete imati problema s praćenjem koraka.
Primjer koda
Primjer koda u nastavku dio je datoteke DeleteSms.rb. Ovaj Ruby kod će izbrisati poruku s ID-om pohranjenim u varijabli msg.id (Slika 3). Možete modificirati varijablu kako bi kod izbrisao drugu poruku. Ako ste upoznati s Ruby programskim jezikom, slobodno modificirajte kod prema vlastitim željama.
Kako koristiti primjerni projekt (Video tutorial)
U ovom videu pokazat ćemo vam kako možete pokrenuti projekt koji briše odabranu poruku. Počet će s pokretanjem Ozeki SMS Gatewaya i završit će s praznim mapom "inbox" iz koje je poruka izbrisana. Ovaj 1:12 dug video objašnjava sve što trebate učiniti kako biste pokrenuli projekt. Koristimo Ozeki SMS Gateway koji nudi vrlo intuitivno korisničko sučelje tako da nećete imati problema s praćenjem koraka.
Sažetak
Gornji članak pokazao je korake brisanja SMS-a u Rubyju uz pomoć Ozeki SMS Gatewaya. Održavanje uravnoteženog prostora za pohranu i često čišćenje "inbox" mape važno je ako redovito radite s SMS-ovima. Ovo rješenje sjajan je primjer koliko je lako upravljati Ozeki SMS Gatewayom s Ruby kodovima. Također treba spomenuti da Ozeki SMS Gateway omogućuje prijavu SMS poruka u bazu podataka i nudi brojne mogućnosti izvještavanja kako bi pružio više informacija o SMS vezi.
Ne završavajte svoje učenje ovdje, posjetite Ozekijevu stranicu s tutorijalima i pročitajte više o stvarima poput slanja više SMS-ova u Rubyju.
Jedino što sada preostaje je preuzeti Ozeki SMS Gateway i neka počne rad!
More information
- Ruby pošalji SMS s HTTP REST API-jem (primjer koda)
- Ruby pošalji više SMS-ova s HTTP REST API-jem (primjer koda)
- Ruby zakazani SMS s HTTP REST API-jem (primjer koda)
- Ruby primi SMS s HTTP REST API-jem (primjer koda)
- Ruby obriši SMS s HTTP REST API-jem (primjer koda)
- Kako preuzeti najnoviju Ruby SMS biblioteku s Githuba
- Ruby pošalji SMS s Linuxa