Dieser Artikel zeigt, dass das Erstellen einer Wettervorhersage -Telefonanwendung mit Twilio und Laravel erstellt wird. Diese zweiteilige Serie konzentriert sich auf die Sprachinteraktion in Teil 1, wobei die SMS-Funktionalität in Teil zwei hinzugefügt wird.
Benutzer rufen eine Twilio -Nummer an, geben eine Postleitzahl ein und erhalten die aktuelle Wettervorhersage. Ein Sprachmenü ermöglicht das Abrufen von Prognosen für bestimmte Wochentage.
Schlüsselmerkmale:
Voraussetzungen:
cd ~/Code composer create-project --prefer-dist laravel/laravel Laravel 5.4.* cd Laravel composer require "twilio/sdk:^5.7" composer require "guzzlehttp/guzzle:~6.0"
Entwicklungsschritte:
routes/web.php
): Routen für Sprachinteraktionen definieren: Route::group(['prefix' => 'voice', 'middleware' => 'twilio'], function () { Route::post('enterZipcode', 'VoiceController@showEnterZipcode')->name('enter-zip'); Route::post('zipcodeWeather', 'VoiceController@showZipcodeWeather')->name('zip-weather'); Route::post('dayWeather', 'VoiceController@showDayWeather')->name('day-weather'); Route::post('credits', 'VoiceController@showCredits')->name('credits'); });
Service Layer (app/Services/WeatherService.php
): Erstellen Sie eine WeatherService
-Klassent, um die Geschäftslogik zu verkapulieren. In dieser Klasse werden Abrufdaten von der National Weather Service -API (https://api.weather.gov
) abgerufen, wobei geografische Daten von Geonames verwendet werden. Das Caching wird für eine verbesserte Leistung implementiert. Die Schlüsselmethoden sind getWeather
, retrieveNwsData
, getPoint
, getTimeZone
, getTimestamp
und getCredits
.
Controller (app/Http/Controllers/VoiceController.php
): Die VoiceController
verwaltet die Benutzerinteraktionen mit dem Abrufen von Wetterdaten. Zu den Methoden gehören WeatherService
, showEnterZipcode
, showZipcodeWeather
und showDayWeather
. Diese Methoden geben Twilio Twiml -Antworten zurück, die den Benutzer durch den Anruf führen. showCredits
Middleware (): app/Http/Middleware/TwilioRequestValidator.php
Eine benutzerdefinierte Middleware überprüft eingehende Anforderungen von Twilio mit dem Twilio RequestValidator, um sicherzustellen, dass nur legitime Anforderungen bearbeitet werden. CSRF -Schutz ist für Twilio Webhooks deaktiviert.
Umgebungsvariablen (.env
): Konfigurieren Sie Ihr Twilio Autht -Token (TWILIO_APP_TOKEN
) und Geonames Benutzername (GEONAMES_USERNAME
).
ngrok: Verwenden Sie NGROK, um Ihren lokalen Entwicklungsserver für Twilio Webhook -Anrufe dem Internet aufzuteilen. Denken Sie daran, die Option -host-header
zu verwenden, um den Host -Header korrekt zu behandeln.
Twilio Setup: Erhalten Sie eine Twilio -Telefonnummer mit Sprach- und SMS -Funktionen. Konfigurieren Sie die Webhook-URLs in Ihren Twilio-Kontoeinstellungen, um auf Ihre NGROK-exponierten Routen zu verweisen.
Produktionsüberlegungen: Umschalten auf HTTPS -Endpunkte wird für Produktionsbereitstellungen empfohlen.
Schlussfolgerung: Dieser Artikel beschreibt eine funktionale sprachbasierte Wetteranwendung. Teil zwei wird dies um SMS -Funktionen erweitern. Das GitHub -Repository (Link, das nicht im Originaltext angegeben ist) enthält den vollständigen Code.
FAQs (aus dem Originaltext, formatiert):
Der FAQS -Abschnitt aus dem Originaltext ist umfangreich und deckt verschiedene Aspekte der Integration von Laravel in verschiedene Kommunikationsdienste (Twilio, Plivo, Sinch) ab. Da die Frage nur darum stellt, den bereitgestellten Text neu zu schreiben, habe ich diesen Abschnitt für die Kürze weggelassen. Wenn Sie diesen Abschnitt jedoch enthalten möchten, lassen Sie es mich bitte wissen.
Das obige ist der detaillierte Inhalt vonHallo, Laravel? Kommunizieren Sie mit PHP über Telefonanrufe!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!