Wie man mehrere SMS aus Objective C versendet
Der einfachste Weg, mehrere SMS aus Objective-C zu versenden, ist die Verwendung der integrierten HTTP/Rest-SMS-API des Ozeki SMS Gateways. Wenn Sie diese API verwenden, senden Sie SMS-Nachrichten, indem Sie eine HTTP-Post-Anfrage an das SMS-Gateway stellen. Die HTTP-Post-Anfrage wird eine Nachricht im JSON-Format enthalten. Das SMS-Gateway wird diese SMS an das Telefon des Empfängers senden und eine HTTP-200-OK-Antwort auf Ihre Anfrage zurückgeben.
Objective-C-Code zum Versenden mehrerer SMS an Mobiltelefone
Das folgende Objective-C-SMS-Codebeispiel zeigt, wie Sie SMS mit der HTTP-Rest-SMS-API des Ozeki SMS Gateways unter Verwendung der Ozeki.Libs.Rest-Bibliothek versenden können. Diese Bibliothek wird Ihnen kostenlos zur Verfügung gestellt, und Sie können sie verwenden und in Ihren Projekten nach Belieben anpassen.
SendMultipleSms.m#import <Foundation/Foundation.h> #import "Ozeki.Libs.Rest.h" int main(int argc, const char * argv[]) { Configuration * configuration = [ [ Configuration alloc ] init]; [ configuration setUsername : @"http_user" ]; [ configuration setPassword : @"qwe123" ]; [ configuration setApiUrl : @"http://192.168.0.14:9509/api" ]; // Sie müssen die IP-Adresse durch die IP des Computers ersetzen, auf dem das SMS-Gateway läuft! MessageApi * api = [ [ MessageApi alloc ] initWithConfiguration : configuration ]; Message * msg1 = [ [ Message alloc ] init ]; [ msg1 setToAddress : @"+36201111111" ]; [ msg1 setText : @"Hello world 1" ]; Message * msg2 = [ [ Message alloc ] init ]; [ msg2 setToAddress : @"+36202222222" ]; [ msg2 setText : @"Hello world 2" ]; Message * msg3 = [ [ Message alloc ] init ]; [ msg3 setToAddress : @"+36203333333" ]; [ msg3 setText : @"Hello world 3" ]; NSMutableArray<Message *> * messages = [ [ NSMutableArray<Message *> alloc ] initWithObjects: msg1, msg2, msg3, nil ]; MessageSendResults * result = [ api SendMessages: messages ]; NSLog(@"%@", result); return 0; }
Wie man das Objective-C-SMS-Beispiel verwendet:
Dieses Objective-C-SMS-Beispiel kann in jeder Objective-C-Core-Anwendung verwendet werden. Um es zu verwenden, müssen Sie die Header-Datei Ozeki.Libs.Rest.h und die Implementierungsdatei Ozeki.Libs.Rest.m zu Ihrem Projekt hinzufügen. Nachdem die Projektreferenz hinzugefügt wurde, müssen Sie die Direktive using Ozeki.Libs.Rest; in den Header-Bereich Ihres Objective-C-Quellcodes einfügen. Dadurch können Sie die Klassen der Ozeki.Libs.Rest-Bibliothek verwenden. Sie können die Message-Klasse verwenden, um die SMS zu erstellen. Sie können die MessageApi-Klasse verwenden, um die SMS an das SMS-Gateway zu senden. Das SMS-Gateway leitet Ihre Nachricht entweder über eine drahtlose Verbindung oder über das Internet an das Mobilfunknetz weiter.
SendMultipleSms.m herunterladen
Der in diesem Artikel erklärte Quellcode kann kostenlos heruntergeladen, verwendet und modifiziert werden.
Download: SendMultipleSms.m.zip (48,4Kb)
Was befindet sich in der SendMultipleSms.m-Datei?
Die SendMultipleSms.m-Datei enthält die Ozeki.Libs.Rest-Bibliothek, die Ihnen alle notwendigen Werkzeuge zum Senden und Empfangen von SMS-Nachrichten bietet. Sie finden auch das SendMultipleSms-Projekt in der ZIP-Datei, das den Beispielcode enthält, der Ihnen zeigt, wie Sie eine SMS versenden. Dieser Beispielcode ist unten aufgeführt.
Wie man mehrere SMS aus Objective-C versendet (Schnelle Schritte)
Um mehrere SMS aus Objective-C zu versenden:
- Installieren Sie einen HTTP-API-Benutzer auf einem Windows-Computer
- Aktivieren Sie "Log communication events" auf dem Reiter "Advanced"
- Richten Sie Xcode ein
- Laden Sie die Datei SendMultipleSms.m.zip herunter und entpacken Sie sie
- Öffnen Sie die Datei SendMultipleSms.xcodeproj in Xcode
- Starten Sie die Ozeki SMS Gateway App auf Ihrem Windows-Computer
- Führen Sie den Objective-C-Code SendMultipleSms.m in Xcode aus
- Überprüfen Sie die Logs, um zu sehen, ob die SMS gesendet wurde
Ozeki SMS Gateway installieren und einen HTTP-API-Benutzer erstellen
Um SMS aus Objective-C versenden zu können, müssen Sie zunächst Ozeki SMS Gateway installieren. Das SMS-Gateway kann auf demselben Computer installiert werden, auf dem Sie Ihren Objective-C-Code in Visual Studio entwickeln. Nach der Installation ist der nächste Schritt, Ozeki SMS Gateway mit dem Mobilfunknetz zu verbinden. Sie können Erstellung eines HTTP-SMS-API-Benutzerkontos. Erstellen Sie einen Benutzer mit dem Benutzernamen "http_user" und dem Passwort "qwe123", damit das Beispiel ohne Änderungen funktioniert.
Nachdem die Umgebung eingerichtet ist, können Sie Ihren Objective-C-Code ausführen.
HTTP-API-URL zum Versenden von SMS aus Objective-C
Um SMS aus Objective-C zu versenden, muss Ihre Objective-C-Anwendung eine HTTP-Anfrage an das SMS-Gateway stellen. Die API-URL wird unten angezeigt. Beachten Sie, dass die IP-Adresse (127.0.0.1) durch die IP-Adresse Ihres SMS-Gateways ersetzt werden sollte. Wenn Ozeki SMS Gateway auf demselben Computer installiert ist, auf dem die Objective-C-SMS-Anwendung läuft, kann dies 127.0.0.1 sein. Wenn es auf einem anderen Computer installiert ist, sollte es die IP-Adresse dieses Computers sein.
http://127.0.0.1:9509/api?action=rest
HTTP-Authentifizierung zum Senden von SMS aus Objective-C
Um den Objective-C-SMS-Client zu authentifizieren, müssen Sie den Benutzernamen und das Passwort in einem base64-kodierten String an den Server in einer HTTP-Anfrage senden. Das verwendete Format lautet: base64(Benutzername+":"+Passwort). In Objective-C können Sie den folgenden Code verwenden, um diese Kodierung durchzuführen:
NSString * username_password = [ NSString stringWithFormat : @"%@:%@", username, password ]; NSData * encode_data = [username_password dataUsingEncoding:NSUTF8StringEncoding]; NSString * username_password_encoded = [encode_data base64EncodedStringWithOptions : 0]; return [ NSString stringWithFormat : @"Basic %@", username_password_encoded ];
Wenn Sie beispielsweise den Benutzernamen 'http_user' und das Passwort 'qwe123' kodieren, erhalten Sie den folgenden base64-kodierten String: aHR0cF91c2VyOnF3ZTEyMw==. Zum Senden
HTTP-Anfrageheader zum Senden von SMS aus Objective-C
Um die SMS-Nachrichten zu senden, müssen Sie die folgenden Zeilen als Header in die HTTP-Anfrage aufnehmen. Beachten Sie, dass wir einen Content-Type und einen Authorization-Header einfügen.
Content-Type: application/json Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
HTTP-Anfrage zum Senden von SMS aus Objective-C
Um die SMS-Nachrichten zu übermitteln, sendet Ihre Objective-C-Anwendung eine HTTP-Anfrage ähnlich der untenstehenden. Beachten Sie, dass diese Anfrage einen HTTP-Header-Teil und einen HTTP-Body-Teil enthält. Der HTTP-Body ist ein JSON-kodierter Datenstring. Er enthält die Empfängernummer und den Nachrichtentext.
POST /api?action=sendmsg HTTP/1.1 Connection: keep-alive Content-Length: 971 Content-Type: application/json Accept: application/json Accept-Encoding: gzip, deflate Accept-Language: en-gb Authorization: Basic aHR0cF91c2VyOnF3ZTEyMw== Host: 192.168.0.14:9509 User-Agent: SendMutipleSms.m (unknown version) CFNetwork/1220.1 Darwin/20.3.0 { "messages": [ { "is_view_report_requested": false, "create_date": "2021-07-23T09:23:25", "message_id": "9c6a7eb2-37b5-4fea-a75f-c0cdaba85466", "time_to_send": "2021-07-23T09:23:25", "valid_until": "2021-07-30T09:23:25", "is_submit_report_requested": false, "to_address": "+36201111111", "text": "Hello world 1", "is_delivery_report_requested": false }, { "is_view_report_requested": false, "create_date": "2021-07-23T09:23:25", "message_id": "8f2ff6cb-417a-4650-a474-8adc4b005cc4", "time_to_send": "2021-07-23T09:23:25", "valid_until": "2021-07-30T09:23:25", "is_submit_report_requested": false, "to_address": "+36202222222", "text": "Hello world 2", "is_delivery_report_requested": false }, { "is_view_report_requested": false, create_date": "2021-07-23T09:23:25", "message_id": "39b54837-a7e5-4319-a154-25d25bf3d920", "time_to_send": "2021-07-23T09:23:25", "valid_until": "2021-07-30T09:23:25", "is_submit_report_requested": false, "to_address": "+36203333333", "text": "Hello world 3", "is_delivery_report_requested": false } ] }
HTTP-Antwort, die vom Objective-C-SMS-Beispiel empfangen wird
Sobald das SMS-Gateway diese Anfrage erhält, wird es eine HTTP-Antwort generieren. Die HTTP-Antwort enthält einen Statuscode, der angibt, ob die SMS-Übermittlungsanfrage erfolgreich war oder nicht. Sie gibt auch eine JSON-kodierte Struktur zurück, die Ihnen nützliche Details über die Nachrichtenübermittlung liefert.
HTTP/1.1 200 OK User-Agent: OZEKI 10.3.123 (www.myozeki.com) Content-Type: application/json; charset=utf8 Last-Modified: Fri, 23 Jul 2021 09:21:44 GMT Server: 10/10.3.123 Transfer-Encoding: chunked { "http_code": 200, "response_code": "SUCCESS", "response_msg": "Messages queued for delivery.", "data": { "total_count": 3, "success_count": 3, "failed_count": 0, "messages": [ { "message_id": "9c6a7eb2-37b5-4fea-a75f-c0cdaba85466", "from_station": "%", "to_address": "+36201111111", "to_station": "%", "text": "Hello world 1", "create_date": "2021-07-23 09:23:25", "valid_until": "2021-07-30 09:23:25", "time_to_send": "2021-07-23 09:23:25", "submit_report_requested": true, "delivery_report_requested": false, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" }, { "message_id": "8f2ff6cb-417a-4650-a474-8adc4b005cc4", "from_station": "%", "to_address": "+36202222222", "to_station": "%", "text": "Hello world 2", "create_date": "2021-07-23 09:23:25", "valid_until": "2021-07-30 09:23:25", "time_to_send": "2021-07-23 09:23:25", "submit_report_requested": true, "delivery_report_requested": false, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" }, { "message_id": "39b54837-a7e5-4319-a154-25d25bf3d920", "from_station": "%", "to_address": "+36203333333", "to_station": "%", "text": "Hello world 3", "create_date": "2021-07-23 09:23:25", "valid_until": "2021-07-30 09:23:25", "time_to_send": "2021-07-23 09:23:25", "submit_report_requested": true, "delivery_report_requested": false, "view_report_requested": false, "tags": [ { "name": "Type", "value": "SMS:TEXT" } ], "status": "SUCCESS" } ] } }
Objective-C-SMS-Beispiel: SendMultipleSms.xcodeproj
Wie man die oben genannte Lösung herunterlädt und öffnet (Video-Tutorial)
In diesem Video zeigen wir Ihnen, wie Sie das Beispielprojekt herunterladen und öffnen können. Es beginnt mit Ihrem Browser auf der Tutorial-Seite und endet mit dem Beispielprojekt auf Ihrem PC. Sie lernen, wo Sie klicken müssen, um die Datei herunterzuladen und wo Sie nach dem Download-Prozess suchen müssen. Das Video ist nur 30 Sekunden lang, sodass Sie keine Probleme haben werden, den Schritten zu folgen.
Der Beispielcode unten ist Teil des SendMultipleSms.xcodeproj-Projekts. In der Zip-Datei gibt es nur ein Projekt: SendMultipleSms.xcodeproj, und drei Dateien: SendMultipleSms.m, Ozeki.Libs.Rest.h, Ozeki.Libs.Rest.m.
Wie man das SendMultipleSms.xcodeproj-Projekt verwendet
Im folgenden Video zeigen wir Ihnen, wie Sie die SendMultipleSMS-Projektdatei verwenden können. Es beginnt mit der leeren Log-Datei des HTTP-Benutzers in Ozeki SMS Gateway und endet mit dem Eintrag des SMS-Versands. Sie lernen, wie Sie die SMS-Sendeanwendung starten und dann das Log des Benutzers überprüfen. Das Video ist fast 1 Minute lang, aber sehr detailliert, sodass Sie keine Probleme haben werden, es zu verstehen. Im Video verwenden wir das Ozeki SMS Gateway, das eine sehr intuitive grafische Oberfläche für ein besseres Benutzererlebnis bietet.
Fazit
Diese Anleitung zeigte die Schritte zum Versenden mehrerer SMS in Objective C mit Hilfe von Ozeki SMS Gateway. Mit diesem ausführlichen Artikel ist es schnell und einfach, mehrere Kunden gleichzeitig zu erreichen. Die Verwendung dieser Funktion ermöglicht das Senden von Nachrichten an mehr Personen, was den Informationsaustausch beschleunigt. Ozeki SMS Gateway arbeitet mit hoher Leistung, was bedeutet, dass es bis zu 1000 SMS pro Sekunde senden kann, sodass das Versenden mehrerer SMS in Objective C mit diesem Programm sehr einfach ist.
Stellen Sie sicher, dass Sie hier nicht aufhören zu lesen, besuchen Sie die Tutorial-Seite von Ozeki, um mehr über ähnliche Themen zu erfahren, wie Empfangen in Objective C.
Das nächste, was Sie tun sollten, ist Ozeki SMS Gateway herunterzuladen und jetzt mit der Arbeit zu beginnen!
More information
- Objective-C SMS mit der HTTP-REST-API senden (Codebeispiel)
- Objective-C mehrere SMS mit der HTTP-REST-API senden (Codebeispiel)
- Objective-C SMS mit der HTTP-REST-API planen (Codebeispiel)
- Objective C SMS mit der HTTP-REST-API empfangen (Codebeispiel)
- Objective C SMS mit der HTTP-REST-API löschen (Codebeispiel)
- So laden Sie die neueste Objective-C-SMS-Bibliothek von Github herunter