Udostępnij za pośrednictwem


Wysyłanie wiadomości tekstowych i multimedialnych Wiadomości WhatsApp przy użyciu zaawansowanej obsługi komunikatów

Usługi Azure Communication Services umożliwiają wysyłanie i odbieranie wiadomości WhatsApp. W tym artykule opisano sposób integrowania aplikacji z zestawem AZURE Communication Advanced Messages SDK w celu rozpoczęcia wysyłania i odbierania wiadomości WhatsApp. Ukończenie tego artykułu wiąże się z niewielkim kosztem kilku centów USD lub mniej na koncie platformy Azure.

Wymagania wstępne

Konfigurowanie środowiska

Tworzenie projektu platformy .NET

Aby utworzyć projekt, postępuj zgodnie z samouczkiem w artykule Create a .NET console application using Visual Studio (Tworzenie aplikacji konsolowej .NET przy użyciu programu Visual Studio).

Aby skompilować kod, naciśnij Ctrl+F7.

Instalowanie pakietu

Zainstaluj pakiet NuGet Azure.Communication.Messages w projekcie języka C#.

  1. Otwórz Menedżer pakietów NuGet pod adresem Project>Manage NuGet Packages....
  2. Wyszukaj pakiet Azure.Communication.Messages.
  3. Zainstaluj najnowszą wersję.

Konfigurowanie struktury aplikacji

Otwórz plik Program.cs w edytorze tekstów.

Zastąp zawartość pliku Program.cs poniższym kodem:

using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using Azure;
using Azure.Communication.Messages;

namespace AdvancedMessagingQuickstart
{
    class Program
    {
        public static async Task Main(string[] args)
        {
            Console.WriteLine("Azure Communication Services - Advanced Messages quickstart samples.");

            // Quickstart code goes here
        }
    }
}

Aby użyć funkcji Advanced Messaging, dodaj dyrektywę using , aby uwzględnić Azure.Communication.Messages przestrzeń nazw.

using Azure.Communication.Messages;

Model obiektów

Następujące klasy i interfejsy obsługują niektóre główne funkcje zestawu AZURE Communication Services Advance Messaging SDK dla platformy .NET.

Nazwa klasy opis
NotificationMessagesClient Nawiązuje połączenie z zasobem usług Azure Communication Services. Wysyła komunikaty.
MessageTemplate Definiuje używany szablon oraz zawartość właściwości szablonu dla wiadomości.
TemplateNotificationContent Definiuje "kto" i "co" wiadomości szablonu, którą zamierzasz wysłać.
TextNotificationContent Definiuje "kto" i "co" wiadomości sms, którą zamierzasz wysłać.
ImageNotificationContent Definiuje "kto" i "co" wiadomości z nośnika obrazów, które zamierzasz wysłać.
DocumentNotificationContent Definiuje "kto" i "co" wiadomości z nośnika dokumentów, które zamierzasz wysłać.
VideoNotificationContent Definiuje "kto" i "co" wiadomości wideo, którą zamierzasz wysłać.
AudioNotificationContent Definiuje wartość "who" i "what" wiadomości audio, którą zamierzasz wysłać.

Uwaga

Aby uzyskać więcej informacji, zobacz Azure SDK for .NET reference Azure.Communication.Messages Namespace (Azure SDK dla platformy .NET — przestrzeń nazw Azure.Communication.Messages).

Typowa konfiguracja

Wykonaj następujące kroki, aby dodać wymagane fragmenty kodu do programu messages-quickstart.py python.

Uwierzytelnianie użytkownika

Zestaw SDK komunikatów używa polecenia do wysyłania NotificationMessagesClient komunikatów. Metoda NotificationMessagesClient uwierzytelnia się przy użyciu parametry połączenia uzyskanych z zasobu usług Azure Communication Services w witrynie Azure Portal. Aby uzyskać więcej informacji na temat parametry połączenia, zobacz access-your-connection-strings-and-service-endpoints.

Dla uproszczenia ten przewodnik Szybki start używa parametry połączenia do uwierzytelniania. W środowiskach produkcyjnych zalecamy używanie jednostek usługi.

Pobierz parametry połączenia z zasobu usług Azure Communication Services w witrynie Azure Portal. Po lewej Keys stronie przejdź do karty. Skopiuj Connection string pole dla klucza podstawowego. Parametry połączenia ma format endpoint=https://{your Azure Communication Services resource name}.communication.azure.com/;accesskey={secret key}.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetlonym polem

Ustaw zmienną środowiskową COMMUNICATION_SERVICES_CONNECTION_STRING na wartość parametry połączenia.
Otwórz okno konsoli i wprowadź następujące polecenie:

setx COMMUNICATION_SERVICES_CONNECTION_STRING "<your connection string>"

Po dodaniu zmiennej środowiskowej może być konieczne ponowne uruchomienie wszystkich uruchomionych programów, które będą musiały odczytać zmienną środowiskową, w tym okno konsoli. Jeśli na przykład używasz programu Visual Studio jako edytora, uruchom ponownie program Visual Studio przed uruchomieniem przykładu.

Aby uzyskać więcej informacji na temat ustawiania zmiennej środowiskowej dla systemu, wykonaj kroki opisane w temacie Przechowywanie parametry połączenia w zmiennej środowiskowej.

Aby utworzyć wystąpienie obiektu NotificationMessagesClient, dodaj następujący kod do Main metody :

// Retrieve connection string from environment variable
string connectionString = 
    Environment.GetEnvironmentVariable("COMMUNICATION_SERVICES_CONNECTION_STRING");

// Instantiate the client
var notificationMessagesClient = new NotificationMessagesClient(connectionString);

Ustawianie identyfikatora rejestracji kanału

Podczas rejestracji kanału utworzono identyfikator GUID identyfikatora rejestracji kanału. Znajdź go w portalu na karcie Kanały zasobu usług Azure Communication Services.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetloną kartą

Przypisz ją do zmiennej o nazwie channelRegistrationId.

var channelRegistrationId = new Guid("<your channel registration ID GUID>");

Ustawianie listy adresatów

Musisz podać aktywny numer telefonu skojarzony z kontem WhatsApp. To konto WhatsApp otrzymuje szablon, tekst i wiadomości multimedialne wysyłane w tym przewodniku Szybki start.

W tym przykładzie możesz użyć osobistego numeru telefonu.

Numer telefonu odbiorcy nie może być numerem telefonu służbowego (identyfikator nadawcy) skojarzonym z rejestracją kanału WhatsApp. Identyfikator nadawcy jest wyświetlany jako nadawca wiadomości tekstowych i multimedialnych wysyłanych do adresata.

Numer telefonu musi zawierać kod kraju. Aby uzyskać więcej informacji na temat formatowania numeru telefonu, zobacz dokumentację WhatsApp dotyczącą formatów numerów telefonów.

Uwaga

Na liście adresatów jest obecnie obsługiwany tylko jeden numer telefonu.

Utwórz listę adresatów w następujący sposób:

var recipientList = new List<string> { "<to WhatsApp phone number>" };

Przykład:

// Example only
var recipientList = new List<string> { "+14255550199" };

Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp

Rozmowy między kontem WhatsApp Business i użytkownikiem WhatsApp można zainicjować na jeden z dwóch sposobów:

  • Firma wysyła wiadomość szablonu do użytkownika WhatsApp.
  • Użytkownik WhatsApp wysyła wszelkie wiadomości do numeru biznesowego.

Firma nie może zainicjować interaktywnej konwersacji. Firma może wysyłać wiadomość interaktywną tylko po otrzymaniu komunikatu od użytkownika. Firma może wysyłać interakcyjne wiadomości tylko do użytkownika podczas aktywnej konwersacji. Po wygaśnięciu 24-godzinnego okna konwersacji tylko użytkownik może ponownie uruchomić konwersację interaktywną. Aby uzyskać więcej informacji na temat rozmów, zobacz definicję na WhatsApp Business Platform.

Aby zainicjować interaktywną konwersację z osobistego konta WhatsApp, wyślij wiadomość do twojego numeru biznesowego (identyfikator nadawcy).

Rozmowa WhatsApp wyświetlona w Internecie pokazująca wiadomość użytkownika wysłaną do numeru konta WhatsApp Business.

Przykłady kodu

Wykonaj następujące kroki, aby dodać wymagane fragmenty kodu do funkcji Program.cs Main pliku.

Ważne

Aby wysłać wiadomość tekstową lub medialną do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Wysyłanie wiadomości SMS do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości tekstowych WhatsApp, które inicjowały użytkowników WhatsApp. Aby wysłać wiadomość SMS, potrzebne są następujące elementy:

W tym przykładzie odpowiadamy użytkownikowi WhatsApp za pomocą tekstu: "Thanks for your feedback.\n From Notification Messaging SDK."

Złóż i wyślij wiadomość SMS:

// Assemble text message
var textContent = 
    new TextNotificationContent(channelRegistrationId, recipientList, "Thanks for your feedback.\n From Notification Messaging SDK");

// Send text message
Response<SendMessageResult> sendTextMessageResult = 
    await notificationMessagesClient.SendAsync(textContent);

Wyślij wiadomość medialną do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych WhatsApp do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Ważne

Od wersji 1.1.0 MediaNotificationContent zestawu SDK jest przestarzała dla obrazów. Zachęcamy do wysyłania ImageNotificationContent obrazów. Zapoznaj się z innymi klasami specyficznymi dla zawartości dla innych typów multimediów, takich jak DocumentNotificationContent, VideoNotificationContenti AudioNotificationContent.

Złóż komunikat obrazu:

var imageLink = new Uri("https://example.com/image.jpg");
var imageNotificationContent = new ImageNotificationContent(channelRegistrationId, recipientList, imageLink)  
{  
    Caption = "Check out this image."  
};

Wyślij komunikat obrazu:

var imageResponse = await notificationMessagesClient.SendAsync(imageNotificationContent);

Wyślij wiadomość medialną dokumentu do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych WhatsApp do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Zmontuj zawartość dokumentu:

var documentLink = new Uri("https://example.com/document.pdf");
var documentNotificationContent = new DocumentNotificationContent(channelRegistrationId, recipientList, documentLink)  
{  
    Caption = "Check out this document.",  
    FileName = "document.pdf"  
};

Wyślij komunikat o dokumencie:

var documentResponse = await notificationMessagesClient.SendAsync(documentNotificationContent);

Wysyłanie wiadomości z mediów wideo do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych WhatsApp do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Zmontuj komunikat wideo:

var videoLink = new Uri("https://example.com/video.mp4");
var videoNotificationContent = new VideoNotificationContent(channelRegistrationId, recipientList, videoLink)  
{  
    Caption = "Check out this video."  
};

Wyślij wiadomość wideo:

var videoResponse = await notificationMessagesClient.SendAsync(videoNotificationContent);

Wysyłanie wiadomości audio medialne do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych WhatsApp do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Złóż komunikat dźwiękowy:

var audioLink = new Uri("https://example.com/audio.mp3");
var audioNotificationContent = new AudioNotificationContent(channelRegistrationId, recipientList, audioLink);

Wyślij wiadomość dźwiękową:

var audioResponse = await notificationMessagesClient.SendAsync(audioNotificationContent);

Uruchamianie kodu

Skompiluj i uruchom program.

Aby wysłać wiadomość tekstową lub medialną do użytkownika WhatsApp, musi istnieć aktywna rozmowa między Kontem Biznesowym WhatsApp a użytkownikiem WhatsApp.

Jeśli nie masz aktywnej konwersacji, na potrzeby tego przykładu dodaj oczekiwanie między wysłaniem wiadomości szablonu i wysłaniem wiadomości SMS. To dodatkowe opóźnienie daje wystarczająco dużo czasu, aby odpowiedzieć na firmę na koncie WhatsApp użytkownika. Pełny przykład w sekcji Przykładowy kod wyświetla monit o ręczne wprowadzanie danych przez użytkownika przed wysłaniem następnego komunikatu.

W przypadku powodzenia otrzymasz trzy wiadomości na koncie WhatsApp użytkownika.

  1. Aby skompilować kod, naciśnij Ctrl+F7.
  2. Aby uruchomić program bez debugowania, naciśnij Ctrl+F5.

Pełny przykładowy kod

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Azure;
using Azure.Communication.Messages;

namespace AdvancedMessagingQuickstart
{
    class Program
    {
        public static async Task Main(string[] args)
        {
            Console.WriteLine("Azure Communication Services - Send WhatsApp Messages\n");

            string connectionString = Environment.GetEnvironmentVariable("COMMUNICATION_SERVICES_CONNECTION_STRING");
            NotificationMessagesClient notificationMessagesClient = 
                new NotificationMessagesClient(connectionString);

            var channelRegistrationId = new Guid("<Your Channel ID>");
            var recipientList = new List<string> { "<Recipient's WhatsApp Phone Number>" };

            // Send sample template sample_template
            string templateName = "sample_template";
            string templateLanguage = "en_us";
            MessageTemplate sampleTemplate = new MessageTemplate(templateName, templateLanguage);
            TemplateNotificationContent templateContent = 
                new TemplateNotificationContent(channelRegistrationId, recipientList, sampleTemplate);
            Response<SendMessageResult> sendTemplateMessageResult = 
                await notificationMessagesClient.SendAsync(templateContent);

            PrintResult(sendTemplateMessageResult);
            Console.WriteLine("Template message sent.\nWait until the WhatsApp user responds " +
                "to the template message, then press any key to continue.\n");
            Console.ReadKey();

            // Send a text message
            string messageText = "Thanks for your feedback.";
            TextNotificationContent textContent =
                new TextNotificationContent(channelRegistrationId, recipientList, messageText);
            Response<SendMessageResult> sendTextMessageResult =
                await notificationMessagesClient.SendAsync(textContent);

            PrintResult(sendTextMessageResult);
            Console.WriteLine($"Text message sent to my phoneNumber.\nPress any key to continue.\n");
            Console.ReadKey();

            // Send a media message
            Uri uri = new Uri("https://aka.ms/acsicon1");
            ImageNotificationContent imageContent =
                new ImageNotificationContent(channelRegistrationId, recipientList, uri);
            Response<SendMessageResult> sendMediaMessageResult =
                await notificationMessagesClient.SendAsync(imageContent);

            PrintResult(sendMediaMessageResult);
            Console.WriteLine("Media message sent.\nPress any key to exit.\n");
            Console.ReadKey();
        }

        public static void PrintResult(Response<SendMessageResult> result)
        {
            Console.WriteLine($"Response: {result.GetRawResponse().Status} " +
                $"({result.GetRawResponse().ReasonPhrase})");
            Console.WriteLine($"Date: " +
                $"{result.GetRawResponse().Headers.First(header => header.Name == "Date").Value}");
            Console.WriteLine($"ClientRequestId: {result.GetRawResponse().ClientRequestId}");
            Console.WriteLine($"MS-CV: " +
                $"{result.GetRawResponse().Headers.First(header => header.Name == "MS-CV").Value}");
            foreach (var receipts in result.Value.Receipts)
            {
                Console.WriteLine($"MessageId: {receipts.MessageId}");
            }
            Console.WriteLine($"\n");
        }
    }
}

Wymagania wstępne

Konfigurowanie środowiska

Aby skonfigurować środowisko wysyłania komunikatów, wykonaj kroki opisane w poniższych sekcjach.

Tworzenie nowej aplikacji Java

Otwórz okno terminalu lub polecenia i przejdź do katalogu, w którym chcesz utworzyć aplikację Java. Uruchom następujące polecenie, aby wygenerować projekt Java na podstawie szablonu maven-archetype-quickstart .

mvn archetype:generate -DgroupId="com.communication.quickstart" -DartifactId="communication-quickstart" -DarchetypeArtifactId="maven-archetype-quickstart" -DarchetypeVersion="1.4" -DinteractiveMode="false"

Cel generate tworzy katalog o takiej samej nazwie jak artifactId wartość. W tym katalogu src/main/java katalog zawiera kod źródłowy projektu, src/test/java katalog zawiera źródło testowe, a pom.xml plik jest projektem Project Object Model (POM).

Instalowanie pakietu

pom.xml Otwórz plik w edytorze tekstów. Dodaj następujący element zależności do grupy zależności.

<dependency>
    <groupId>com.azure</groupId>
    <artifactId>azure-communication-messages</artifactId>
</dependency>

Konfigurowanie struktury aplikacji

Otwórz /src/main/java/com/communication/quickstart/App.java w edytorze tekstów, dodaj dyrektywy importu i usuń instrukcję System.out.println("Hello world!"); :

package com.communication.quickstart;

import com.azure.communication.messages.*;
import com.azure.communication.messages.models.*;

import java.util.ArrayList;
import java.util.List;
public class App
{
    public static void main( String[] args )
    {
        // Quickstart code goes here.
    }
}

Przykłady kodu

Wykonaj następujące kroki, aby dodać wymagane fragmenty kodu do funkcji App.java main pliku.

Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp

Rozmowy między kontem WhatsApp Business i użytkownikiem WhatsApp można zainicjować na jeden z dwóch sposobów:

  • Firma wysyła wiadomość szablonu do użytkownika WhatsApp.
  • Użytkownik WhatsApp wysyła wszelkie wiadomości do numeru biznesowego.

Niezależnie od sposobu rozpoczęcia konwersacji firma może wysyłać tylko wiadomości szablonów, dopóki użytkownik nie wyśle wiadomości do firmy. Dopiero po wysłaniu wiadomości do firmy przez użytkownika firma może wysyłać wiadomości tekstowe lub multimedialne do użytkownika podczas aktywnej konwersacji. Po wygaśnięciu 24-godzinnego okna konwersacji należy ponownie zainicjować konwersację. Aby dowiedzieć się więcej o rozmowach, zobacz definicję na WhatsApp Business Platform.

Uwierzytelnianie użytkownika

Istnieje kilka różnych opcji uwierzytelniania klienta komunikatów:

Aby uwierzytelnić klienta, należy utworzyć wystąpienie elementu NotificationMessagesClient lub MessageTemplateClient przy użyciu parametry połączenia. Można również zainicjować klienta przy użyciu dowolnego niestandardowego klienta HTTP, który implementuje com.azure.core.http.HttpClient interfejs.

Dla uproszczenia ten przewodnik Szybki start używa parametry połączenia do uwierzytelniania. W środowiskach produkcyjnych zalecamy używanie jednostek usługi.

Pobierz parametry połączenia z zasobu usług Azure Communication Services w witrynie Azure Portal. Po lewej Keys stronie przejdź do karty. Skopiuj Connection string pole dla elementu Primary key. Parametry połączenia ma format endpoint=https://{your Azure Communication Services resource name}.communication.azure.com/;accesskey={secret key}.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetlonym polem

Ustaw zmienną środowiskową COMMUNICATION_SERVICES_CONNECTION_STRING na wartość parametry połączenia.
Otwórz okno konsoli i wprowadź następujące polecenie:

setx COMMUNICATION_SERVICES_CONNECTION_STRING "<your connection string>"

Aby uzyskać więcej informacji na temat ustawiania zmiennej środowiskowej dla systemu, wykonaj kroki opisane w temacie Przechowywanie parametry połączenia w zmiennej środowiskowej.

Aby utworzyć wystąpienie klasy NotificationMessagesClient, dodaj następujący kod do main metody :

// You can get your connection string from your resource in the Azure portal.
String connectionString = System.getenv("COMMUNICATION_SERVICES_CONNECTION_STRING");

NotificationMessagesClient notificationClient = new NotificationMessagesClientBuilder()
    .connectionString(connectionString)
    .buildClient();

Ustawianie identyfikatora rejestracji kanału

Identyfikator GUID identyfikatora rejestracji kanału został utworzony podczas rejestracji kanału. Możesz wyszukać go w portalu na karcie Kanały zasobu usług Azure Communication Services.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetloną kartą

Przypisz ją do zmiennej o nazwie channelRegistrationId.

String channelRegistrationId = "<your channel registration id GUID>";

Ustawianie listy adresatów

Musisz podać rzeczywisty numer telefonu, który ma skojarzone konto WhatsApp. To konto WhatsApp otrzymuje wiadomości tekstowe i multimedialne wysyłane w tym przewodniku Szybki start. W tym przewodniku Szybki start ten numer telefonu może być osobistym numerem telefonu.

Numer telefonu odbiorcy nie może być numerem telefonu służbowego (identyfikator nadawcy) skojarzonym z rejestracją kanału WhatsApp. Identyfikator nadawcy jest wyświetlany jako nadawca wiadomości tekstowych i multimedialnych wysyłanych do adresata.

Numer telefonu powinien zawierać kod kraju. Aby uzyskać więcej informacji na temat formatowania numeru telefonu, zobacz dokumentację WhatsApp dotyczącą formatów numerów telefonów.

Uwaga

Na liście adresatów jest obecnie obsługiwany tylko jeden numer telefonu.

Utwórz listę adresatów w następujący sposób:

List<String> recipientList = new ArrayList<>();
recipientList.add("<to WhatsApp phone number>");

Przykład:

// Example only
List<String> recipientList = new ArrayList<>();
recipientList.add("+14255550199");

Wysyłanie wiadomości SMS do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości sms WhatsApp, które inicjowały użytkowników WhatsApp. Aby wysłać wiadomości SMS poniżej, wymagane są następujące szczegóły:

W tym przykładzie odpowiadamy użytkownikowi WhatsApp za pomocą tekstu "Thanks for your feedback.\n From Notification Messaging SDK."

Ważne

Aby wysłać wiadomość SMS do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Złóż i wyślij wiadomość SMS:

// Assemble text message
TextNotificationContent textContent = new TextNotificationContent(channelRegistrationId, recipientList, "“Thanks for your feedback.\n From Notification Messaging SDK");

// Send text message
SendMessageResult textMessageResult = notificationClient.send(textContent);

// Process result
for (MessageReceipt messageReceipt : textMessageResult.getReceipts()) {
    System.out.println("Message sent to:" + messageReceipt.getTo() + " and message id:" + messageReceipt.getMessageId());
}

Wyślij wiadomość medialną do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Ważne

Od wersji 1.1.0 MediaNotificationContent zestawu SDK jest przestarzała dla obrazów. Zachęcamy do ImageNotificationContent wysyłania obrazów. Zapoznaj się z innymi klasami specyficznymi dla zawartości dla innych typów multimediów, takich jak DocumentNotificationContent, VideoNotificationContenti AudioNotificationContent.

Ważne

Aby wysłać wiadomość obrazu do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Złóż i wyślij komunikat obrazu:

// Assemble image message
String imageUrl = "https://example.com/image.jpg";
ImageNotificationContent imageContent = new ImageNotificationContent(channelRegistrationId, recipientList, imageUrl);

// Send image message
SendMessageResult imageMessageResult = notificationClient.send(imageContent);

// Process result
for (MessageReceipt messageReceipt : imageMessageResult.getReceipts()) {
    System.out.println("Message sent to:" + messageReceipt.getTo() + " and message id:" + messageReceipt.getMessageId());
}

Wysyłanie wiadomości z mediów wideo do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Ważne

Aby wysłać wiadomość wideo do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Złóż i wyślij komunikat wideo:

// Assemble video message
String videoUrl = "https://example.com/video.mp4";
VideoNotificationContent videoContent = new VideoNotificationContent(channelRegistrationId, recipientList, videoUrl);

// Send video message
SendMessageResult videoMessageResult = notificationClient.send(videoContent);

// Process result
for (MessageReceipt messageReceipt : videoMessageResult.getReceipts()) {
    System.out.println("Message sent to:" + messageReceipt.getTo() + " and message id:" + messageReceipt.getMessageId());
}

Wysyłanie wiadomości audio medialne do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Ważne

Aby wysłać wiadomość dźwiękową do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Złóż i wyślij wiadomość dźwiękową:

// Assemble audio message
String audioUrl = "https://example.com/audio.mp3";
AudioNotificationContent audioContent = new AudioNotificationContent(channelRegistrationId, recipientList, audioUrl);

// Send audio message
SendMessageResult audioMessageResult = notificationClient.send(audioContent);

// Process result
for (MessageReceipt messageReceipt : audioMessageResult.getReceipts()) {
    System.out.println("Message sent to:" + messageReceipt.getTo() + " and message id:" + messageReceipt.getMessageId());
}

Wyślij wiadomość medialną dokumentu do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Ważne

Aby wysłać wiadomość dokumentu do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Złóż i wyślij komunikat dokumentu:

// Assemble document message
String docUrl = "https://example.com/document.pdf";
DocumentNotificationContent docContent = new DocumentNotificationContent(channelRegistrationId, recipientList, docUrl);

// Send document message
SendMessageResult docMessageResult = notificationClient.send(docContent);

// Process result
for (MessageReceipt messageReceipt : docMessageResult.getReceipts()) {
    System.out.println("Message sent to:" + messageReceipt.getTo() + " and message id:" + messageReceipt.getMessageId());
}

Uruchamianie kodu

  1. Otwórz katalog zawierający pom.xml plik i skompiluj projekt przy użyciu mvn polecenia .

    mvn compile
    
  2. Uruchom aplikację, wykonując następujące mvn polecenie.

    mvn exec:java -D"exec.mainClass"="com.communication.quickstart.App" -D"exec.cleanupDaemonThreads"="false"
    

Pełny przykładowy kod

Znajdź sfinalizowany kod dla tego przewodnika Szybki start w witrynie GitHub.

Wymagania wstępne

  • Konto WhatsApp Business zarejestrowane w zasobie usług Azure Communication Services.
  • Aktywny numer telefonu WhatsApp do odbierania wiadomości.
  • Node.js wersji Active LTS i Maintenance LTS (zalecamy wersje 8.11.1 i 10.14.1).
  • Node.js wersji LTS Active LTS i Maintenance LTS (zalecane są wersje 8.11.1 i 10.14.1)
    • W terminalu lub oknie polecenia uruchom polecenie node --version , aby sprawdzić, czy Node.js jest zainstalowana

Konfigurowanie

Tworzenie nowej aplikacji Node.js

  1. Utwórz nowy katalog aplikacji i otwórz go w terminalu lub oknie polecenia.

  2. Uruchom następujące polecenie.

    mkdir advance-messages-quickstart && cd advance-messages-quickstart
    
  3. Uruchom następujące polecenie, aby utworzyć package.json plik z ustawieniami domyślnymi.

    npm init -y
    
  4. Użyj edytora tekstów, aby utworzyć plik o nazwie send-messages.js w katalogu głównym projektu.

  5. Dodaj następujący fragment kodu do pliku send-messages.js.

    async function main() {
        // Quickstart code goes here.
    }
    
    main().catch((error) => {
        console.error("Encountered an error while sending message: ", error);
        process.exit(1);
    });
    

Ukończ następującą sekcję, aby dodać kod źródłowy dla tego przykładu do utworzonego send-messages.js pliku.

Instalowanie pakietu

Użyj polecenia , npm install aby zainstalować zestaw AZURE Communication Services Advance Messaging SDK dla języka JavaScript.

npm install @azure-rest/communication-messages --save

Opcja --save wyświetla bibliotekę jako zależność w pliku package.json .

Przykłady kodu

Wykonaj następujące kroki, aby dodać wymagane fragmenty kodu do funkcji send-messages.js main pliku.

Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp

Rozmowy między kontem WhatsApp Business i użytkownikiem WhatsApp można zainicjować na jeden z dwóch sposobów:

  • Firma wysyła wiadomość szablonu do użytkownika WhatsApp.
  • Użytkownik WhatsApp wysyła wszelkie wiadomości do numeru biznesowego.

Niezależnie od sposobu rozpoczęcia konwersacji firma może wysyłać tylko wiadomości szablonów, dopóki użytkownik nie wyśle wiadomości do firmy. Dopiero po wysłaniu wiadomości do firmy przez użytkownika firma może wysyłać wiadomości tekstowe lub multimedialne do użytkownika podczas aktywnej konwersacji. Po wygaśnięciu 24-godzinnego okna konwersacji należy ponownie zainicjować konwersację. Aby dowiedzieć się więcej o rozmowach, zobacz definicję na WhatsApp Business Platform.

Uwierzytelnianie użytkownika

Poniższy kod pobiera parametry połączenia zasobu ze zmiennej środowiskowej o nazwie COMMUNICATION_SERVICES_CONNECTION_STRING przy użyciu pakietu dotenv.

Dla uproszczenia ten przewodnik Szybki start używa parametry połączenia do uwierzytelniania. W środowiskach produkcyjnych zalecamy używanie jednostek usługi.

Pobierz parametry połączenia z zasobu usług Azure Communication Services w witrynie Azure Portal. Po lewej Keys stronie przejdź do karty. Skopiuj Connection string pole dla elementu Primary key. Parametry połączenia ma format endpoint=https://{your Azure Communication Services resource name}.communication.azure.com/;accesskey={secret key}.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetlonym polem

Ustaw zmienną środowiskową COMMUNICATION_SERVICES_CONNECTION_STRING na wartość parametry połączenia.
Otwórz okno konsoli i wprowadź następujące polecenie:

setx COMMUNICATION_SERVICES_CONNECTION_STRING "<your connection string>"

Aby uzyskać więcej informacji na temat ustawiania zmiennej środowiskowej dla systemu, wykonaj kroki opisane w temacie Przechowywanie parametry połączenia w zmiennej środowiskowej.

Aby utworzyć wystąpienie klasy NotificationClient, dodaj następujący kod do Main metody :

const NotificationClient = require("@azure-rest/communication-messages").default;

// Set Connection string
const connectionString = process.env["COMMUNICATION_SERVICES_CONNECTION_STRING"];

// Instantiate the client
const client = NotificationClient(connectionString);

Ustawianie identyfikatora rejestracji kanału

Identyfikator GUID identyfikatora rejestracji kanału został utworzony podczas rejestracji kanału. Możesz wyszukać go w portalu na karcie Kanały zasobu usług Azure Communication Services.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetloną kartą

Przypisz ją do zmiennej o nazwie channelRegistrationId.

const channelRegistrationId = "<your channel registration id GUID>";

Ustawianie listy adresatów

Musisz podać rzeczywisty numer telefonu, który ma skojarzone konto WhatsApp. To konto WhatsApp otrzymuje szablon, tekst i wiadomości multimedialne wysyłane w tym przewodniku Szybki start. W tym przewodniku Szybki start ten numer telefonu może być osobistym numerem telefonu.

Numer telefonu odbiorcy nie może być numerem telefonu służbowego (identyfikator nadawcy) skojarzonym z rejestracją kanału WhatsApp. Identyfikator nadawcy jest wyświetlany jako nadawca wiadomości tekstowych i multimedialnych wysyłanych do adresata.

Numer telefonu powinien zawierać kod kraju. Aby uzyskać więcej informacji na temat formatowania numeru telefonu, zobacz dokumentację WhatsApp dotyczącą formatów numerów telefonów.

Uwaga

Na liście adresatów jest obecnie obsługiwany tylko jeden numer telefonu.

Utwórz listę adresatów w następujący sposób:

const recipientList = ["<to WhatsApp phone number>"];

Przykład:

// Example only
const recipientList = ["+14255550199"];

Ważne

Aby wysłać wiadomość do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Wysyłanie wiadomości SMS do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie sms-ów wiadomości WhatsApp po zainicjowaniu przez użytkowników WhatsApp. Aby wysłać wiadomości SMS:

W tym przykładzie odpowiadamy użytkownikowi WhatsApp za pomocą tekstu "Thanks for your feedback.\n From Notification Messaging SDK."

Złóż i wyślij wiadomość SMS:

// Send text message
const textMessageResult = await client.path("/messages/notifications:send").post({
    contentType: "application/json",
    body: {
        channelRegistrationId: channelRegistrationId,
        to: recipientList,
        kind: "text",
        content: "Thanks for your feedback.\n From Notification Messaging SDK"
    }
});

// Process result
if (textMessageResult.status === "202") {
    textMessageResult.body.receipts.forEach((receipt) => {
        console.log("Message sent to:"+receipt.to+" with message id:"+receipt.messageId);
    });
} else {
    throw new Error("Failed to send message");
}

Wyślij wiadomość medialną do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Ważne

Od wersji 2.0.0 MediaNotificationContent zestawu SDK jest przestarzały dla obrazów. Zachęcamy do ImageNotificationContent wysyłania obrazów. Zapoznaj się z innymi klasami specyficznymi dla zawartości dla innych typów multimediów, takich jak DocumentNotificationContent, VideoNotificationContenti AudioNotificationContent.

Aby wysłać komunikat obrazu, podaj adres URL obrazu. Na przykład:

const url = "https://example.com/image.jpg";

Złóż i wyślij komunikat multimedialny:

// Send image message
const mediaMessageResult = await client.path("/messages/notifications:send").post({
    contentType: "application/json",
    body: {
        channelRegistrationId: channelRegistrationId,
        to: recipientList,
        kind: "image",
        mediaUri: url
    }
});

// Process result
if (mediaMessageResult.status === "202") {
    mediaMessageResult.body.receipts.forEach((receipt) => {
        console.log("Message sent to:"+receipt.to+" with message id:"+receipt.messageId);
    });
} else {
    throw new Error("Failed to send message");
}

Wysyłanie wiadomości z mediów wideo do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Aby wysłać wiadomość wideo, podaj adres URL filmu wideo. Na przykład

const url = "https://example.com/video.mp4";

Złóż i wyślij komunikat wideo:

// Send video message
const mediaMessageResult = await client.path("/messages/notifications:send").post({
    contentType: "application/json",
    body: {
        channelRegistrationId: channelRegistrationId,
        to: recipientList,
        kind: "video",
        mediaUri: url
    }
});

// Process result
if (mediaMessageResult.status === "202") {
    mediaMessageResult.body.receipts.forEach((receipt) => {
        console.log("Message sent to:"+receipt.to+" with message id:"+receipt.messageId);
    });
} else {
    throw new Error("Failed to send message");
}

Wysyłanie wiadomości audio medialne do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Aby wysłać wiadomość dźwiękową, podaj adres URL do pliku audio. Przykład:

const url = "https://example.com/audio.mp3";

Złóż i wyślij wiadomość dźwiękową:

// Send audio message
const mediaMessageResult = await client.path("/messages/notifications:send").post({
    contentType: "application/json",
    body: {
        channelRegistrationId: channelRegistrationId,
        to: recipientList,
        kind: "audio",
        mediaUri: url
    }
});

// Process result
if (mediaMessageResult.status === "202") {
    mediaMessageResult.body.receipts.forEach((receipt) => {
        console.log("Message sent to:"+receipt.to+" with message id:"+receipt.messageId);
    });
} else {
    throw new Error("Failed to send message");
}

Wyślij wiadomość medialną dokumentu do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości multimedialnych (obraz, wideo, audio lub dokument) do użytkowników WhatsApp. Aby wysłać osadzony komunikat multimedialny, potrzebne są następujące elementy:

Aby wysłać komunikat o dokumencie, podaj adres URL do dokumentu. Na przykład

const url = "https://example.com/document.pdf";

Złóż i wyślij komunikat dokumentu:

// Send document message
const mediaMessageResult = await client.path("/messages/notifications:send").post({
    contentType: "application/json",
    body: {
        channelRegistrationId: channelRegistrationId,
        to: recipientList,
        kind: "document",
        mediaUri: url
    }
});

// Process result
if (mediaMessageResult.status === "202") {
    mediaMessageResult.body.receipts.forEach((receipt) => {
        console.log("Message sent to:"+receipt.to+" with message id:"+receipt.messageId);
    });
} else {
    throw new Error("Failed to send message");
}

Uruchamianie kodu

Użyj polecenia node, aby uruchomić kod dodany do send-messages.js pliku.

node ./send-messages.js

Pełny przykładowy kod

Znajdź sfinalizowany kod dla tego przewodnika Szybki start w witrynie GitHub.

Wymagania wstępne

Konfigurowanie

Tworzenie nowej aplikacji w języku Python

W oknie terminalu lub konsoli utwórz nowy folder dla aplikacji i otwórz go.

mkdir messages-quickstart && cd messages-quickstart

Instalowanie pakietu

Użyj biblioteki klienta komunikatów usługi Azure Communication dla języka Python w wersji 1.1.0 lub nowszej.

W wierszu polecenia konsoli uruchom następujące polecenie:

pip install azure-communication-messages

W przypadku komunikatów interaktywnych, reakcji i naklejek użyj poniższej wersji beta :

pip install azure-communication-messages==1.2.0b1

Konfigurowanie struktury aplikacji

Utwórz nowy plik o nazwie messages-quickstart.py i dodaj podstawową strukturę programu.

type nul > messages-quickstart.py   

Podstawowa struktura programu

import os

class MessagesQuickstart(object):
    print("Azure Communication Services - Advanced Messages SDK Quickstart")

if __name__ == '__main__':
    messages = MessagesQuickstart()

Model obiektów

Następujące klasy i interfejsy obsługują niektóre główne funkcje zestawu SDK komunikatów usług Azure Communication Services dla języka Python.

Nazwa klasy opis
NotificationMessagesClient Nawiązuje połączenie z zasobem usług Azure Communication Services. Wysyła komunikaty.
MessageTemplate Definiuje używany szablon oraz zawartość właściwości szablonu dla wiadomości.
TemplateNotificationContent Definiuje "kto" i "co" wiadomości szablonu, którą zamierzasz wysłać.
TextNotificationContent Definiuje "kto" i "co" wiadomości sms, którą zamierzasz wysłać.
ImageNotificationContent Definiuje "kto" i "co" wiadomości z nośnika obrazów, które zamierzasz wysłać.
DocumentNotificationContent Definiuje "kto" i "co" wiadomości z nośnika dokumentów, które zamierzasz wysłać.
VideoNotificationContent Definiuje "kto" i "co" wiadomości wideo, którą zamierzasz wysłać.
AudioNotificationContent Definiuje wartość "who" i "what" wiadomości audio, którą zamierzasz wysłać.

Uwaga

Aby uzyskać więcej informacji, zobacz Pakiet komunikatów referencyjnych zestawu Azure SDK dla języka Python.

Typowa konfiguracja

Wykonaj następujące kroki, aby dodać wymagane fragmenty kodu do messages-quickstart.py programu python.

Uwierzytelnianie użytkownika

Wysyłanie komunikatów odbywa się przy użyciu elementu NotificationMessagesClient. Element NotificationMessagesClient jest uwierzytelniany przy użyciu parametry połączenia uzyskanego z zasobu usług Azure Communication Services w witrynie Azure Portal. Aby uzyskać więcej informacji na temat parametry połączenia, zobacz access-your-connection-strings-and-service-endpoints.

Pobierz parametry połączenia zasobów usługi Azure Communication z witryny Azure Portal, jak pokazano na zrzucie ekranu. Po lewej Keys stronie przejdź do karty. Skopiuj Connection string pole dla klucza podstawowego. Parametry połączenia ma format endpoint=https://{your Azure Communication Services resource name}.communication.azure.com/;accesskey={secret key}.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetlonym polem

Ustaw zmienną środowiskową COMMUNICATION_SERVICES_CONNECTION_STRING na wartość parametry połączenia.
Otwórz okno konsoli i wprowadź następujące polecenie:

setx COMMUNICATION_SERVICES_CONNECTION_STRING "<your connection string>"

Po dodaniu zmiennej środowiskowej może być konieczne ponowne uruchomienie wszystkich uruchomionych programów, które będą musiały odczytać zmienną środowiskową, w tym okno konsoli. Jeśli na przykład używasz programu Visual Studio jako edytora, uruchom ponownie program Visual Studio przed uruchomieniem przykładu.

Aby uzyskać więcej informacji na temat ustawiania zmiennej środowiskowej dla systemu, wykonaj kroki opisane w temacie Przechowywanie parametry połączenia w zmiennej środowiskowej.

    # Get a connection string to our Azure Communication Services resource.
    connection_string = os.getenv("COMMUNICATION_SERVICES_CONNECTION_STRING")
    
    def send_template_message(self):
        from azure.communication.messages import NotificationMessagesClient

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)

Ustawianie identyfikatora rejestracji kanału

Podczas rejestracji kanału utworzono identyfikator GUID identyfikatora rejestracji kanału. Znajdź go w portalu na karcie Kanały zasobu usług Azure Communication Services.

Zrzut ekranu przedstawiający zasób usług Azure Communication Services w witrynie Azure Portal z wyświetloną kartą

Przypisz ją do zmiennej o nazwie channelRegistrationId.

    channelRegistrationId = os.getenv("WHATSAPP_CHANNEL_ID_GUID")

Ustawianie listy adresatów

Musisz podać aktywny numer telefonu skojarzony z kontem WhatsApp. To konto WhatsApp otrzymuje szablon, tekst i wiadomości multimedialne wysyłane w tym przewodniku Szybki start.

W tym przykładzie możesz użyć osobistego numeru telefonu.

Numer telefonu odbiorcy nie może być numerem telefonu służbowego (identyfikator nadawcy) skojarzonym z rejestracją kanału WhatsApp. Identyfikator nadawcy jest wyświetlany jako nadawca wiadomości tekstowych i multimedialnych wysyłanych do adresata.

Numer telefonu musi zawierać kod kraju. Aby uzyskać więcej informacji na temat formatowania numeru telefonu, zobacz dokumentację WhatsApp dotyczącą formatów numerów telefonów.

Uwaga

Na liście adresatów jest obecnie obsługiwany tylko jeden numer telefonu.

Ustaw listę adresatów w następujący sposób:

    phone_number = os.getenv("RECIPIENT_WHATSAPP_PHONE_NUMBER")

Przykład użycia:

    # Example only
    to=[self.phone_number],

Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp

Rozmowy między kontem WhatsApp Business i użytkownikiem WhatsApp można zainicjować na jeden z dwóch sposobów:

  • Firma wysyła wiadomość szablonu do użytkownika WhatsApp.
  • Użytkownik WhatsApp wysyła wszelkie wiadomości do numeru biznesowego.

Firma nie może zainicjować interaktywnej konwersacji. Firma może wysyłać wiadomość interaktywną tylko po otrzymaniu komunikatu od użytkownika. Firma może wysyłać interakcyjne wiadomości tylko do użytkownika podczas aktywnej konwersacji. Po wygaśnięciu 24-godzinnego okna konwersacji tylko użytkownik może ponownie uruchomić konwersację interaktywną. Aby uzyskać więcej informacji na temat rozmów, zobacz definicję na WhatsApp Business Platform.

Aby zainicjować interaktywną konwersację z osobistego konta WhatsApp, wyślij wiadomość do twojego numeru biznesowego (identyfikator nadawcy).

Rozmowa WhatsApp wyświetlona w Internecie pokazująca wiadomość użytkownika wysłaną do numeru konta WhatsApp Business.

Przykłady kodu

Wykonaj następujące kroki, aby dodać wymagane fragmenty kodu do programu messages-quickstart.py python.

Wysyłanie wiadomości SMS do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości sms WhatsApp po zainicjowaniu przez użytkownika WhatsApp. Aby wysłać wiadomości SMS:

Ważne

Aby wysłać wiadomość SMS do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

W tym przykładzie odpowiadamy użytkownikowi WhatsApp za pomocą tekstu "Thanks for your feedback.\n From Notification Messaging SDK."

    def send_text_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( TextNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        text_options = TextNotificationContent (
            channel_registration_id=self.channelRegistrationId,
            to= [self.phone_number],
            content="Thanks for your feedback.\n From Notification Messaging SDK",
        )
        
        # calling send() with whatsapp message details
        message_responses = messaging_client.send(text_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Text Message with message id {} was successfully sent to {}."
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

Aby uruchomić send_text_message()polecenie , zaktualizuj metodę main:

    #Calling send_text_message()
    messages.send_text_message()

Wyślij wiadomość medialną do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie obrazów wiadomości WhatsApp do użytkowników WhatsApp. Aby wysłać osadzone komunikaty obrazu:

Ważne

Aby wysłać wiadomość SMS do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Przykład użycia podczas wysyłania media_uri wiadomości WhatsApp mediów.

input_media_uri: str = "https://aka.ms/acsicon1"

    def send_image_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( ImageNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "https://aka.ms/acsicon1"
        image_message_options = ImageNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            media_uri=input_media_uri
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(image_message_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Image containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

Aby uruchomić send_text_message()polecenie , zaktualizuj metodę main:

    # Calling send_image_message()
    messages.send_image_message()

Wyślij wiadomość medialną dokumentu do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie dokumentów wiadomości WhatsApp do użytkowników WhatsApp. Aby wysłać osadzone komunikaty dokumentu:

Ważne

Aby wysłać wiadomość dokumentu do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Przykład użycia podczas wysyłania media_uri wiadomości WhatsApp mediów.

input_media_uri: str = "##DocumentLinkPlaceholder##"

    def send_document_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( DocumentNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "##DocumentLinkPlaceholder##"
        documents_options = DocumentNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            caption="Hello World via Advanced Messaging SDK.This is document message",
            file_name="Product roadmap timeline.pptx",
            media_uri=input_media_uri,
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(documents_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Document containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

Aby uruchomić send_text_message()polecenie , zaktualizuj metodę main:

    # Calling send_image_message()
    messages.send_image_message()

Wysyłanie wiadomości audio medialne do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie obrazów wiadomości WhatsApp do użytkowników WhatsApp. Aby wysyłać komunikaty osadzone audio:

Ważne

Aby wysłać wiadomość dźwiękową do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Przykład użycia podczas wysyłania media_uri wiadomości WhatsApp mediów.

input_media_uri: str = "##AudioLinkPlaceholder##"

    def send_audio_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( AudioNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "##AudioLinkPlaceholder##"
        audio_options = AudioNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            media_uri=input_media_uri,
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(audio_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Audio containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

Aby uruchomić send_text_message()polecenie , zaktualizuj metodę main:

    # Calling send_image_message()
    messages.send_image_message()

Wysyłanie wiadomości z mediów wideo do użytkownika WhatsApp

Zestaw SDK wiadomości umożliwia firmie Contoso wysyłanie wiadomości wideo WhatsApp do użytkowników WhatsApp. Aby wysłać osadzone komunikaty wideo:

Ważne

Aby wysłać wiadomość wideo do użytkownika WhatsApp, użytkownik WhatsApp musi najpierw wysłać wiadomość na konto WhatsApp Business. Aby uzyskać więcej informacji, zobacz Rozpoczynanie wysyłania wiadomości między firmą a użytkownikiem WhatsApp.

Przykład użycia podczas wysyłania media_uri wiadomości WhatsApp mediów.

input_media_uri: str = "##VideoLinkPlaceholder##"

    def send_video_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( VideoNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "##VideoLinkPlaceholder##"
        video_options = VideoNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            media_uri=input_media_uri,
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(image_message_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Video containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

Aby uruchomić send_text_message()polecenie , zaktualizuj metodę main:

    # Calling send_image_message()
    messages.send_image_message()

Uruchamianie kodu

Aby uruchomić kod, upewnij się, że znajdujesz się w katalogu, w którym messages-quickstart.py znajduje się plik.

python messages-quickstart.py
Azure Communication Services - Advanced Messages Quickstart
WhatsApp Templated Message with message id <<GUID>> was successfully sent to <<ToRecipient>>
WhatsApp Text Message with message id <<GUID>> was successfully sent to <<ToRecipient>>
WhatsApp Image containing Message with message id <<GUID>> was successfully sent to <<ToRecipient>>

Pełny przykładowy kod

Uwaga

Zastąp wszystkie zmienne zastępcze w przykładowym kodzie wartościami.

import os

class MessagesQuickstart(object):
    print("Azure Communication Services - Advanced Messages SDK Quickstart using connection string.")
    # Advanced Messages SDK implementations goes in this section.
   
    connection_string = os.getenv("COMMUNICATION_SERVICES_CONNECTION_STRING")
    phone_number = os.getenv("RECIPIENT_PHONE_NUMBER")
    channelRegistrationId = os.getenv("WHATSAPP_CHANNEL_ID")

    def send_template_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( TemplateNotificationContent , MessageTemplate )

        # client creation
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_template: MessageTemplate = MessageTemplate(
            name="<<TEMPLATE_NAME>>",
            language="<<LANGUAGE>>")
        template_options = TemplateNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            template=input_template
        )

        # calling send() with WhatsApp template details.
        message_responses = messaging_client.send(template_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Templated Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

    def send_text_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( TextNotificationContent )

        # client creation
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)

        text_options = TextNotificationContent (
            channel_registration_id=self.channelRegistrationId,
            to= [self.phone_number],
            content="Hello World via ACS Advanced Messaging SDK.",
        )
        
        # calling send() with WhatsApp message details
        message_responses = messaging_client.send(text_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Text Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

    def send_image_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( ImageNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "https://aka.ms/acsicon1"
        image_message_options = ImageNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            media_uri=input_media_uri
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(image_message_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Image containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")
    
    def send_document_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( DocumentNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "##DocumentLinkPlaceholder##"
        documents_options = DocumentNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            caption="Hello World via Advanced Messaging SDK.This is document message",
            file_name="Product roadmap timeline.pptx",
            media_uri=input_media_uri,
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(documents_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Document containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

    def send_audio_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( AudioNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "##AudioLinkPlaceholder##"
        audio_options = AudioNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            media_uri=input_media_uri,
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(audio_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Audio containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

    def send_video_message(self):
        from azure.communication.messages import NotificationMessagesClient
        from azure.communication.messages.models import ( VideoNotificationContent)

        # Create NotificationMessagesClient Client
        messaging_client = NotificationMessagesClient.from_connection_string(self.connection_string)
        input_media_uri: str = "##VideoLinkPlaceholder##"
        video_options = VideoNotificationContent(
            channel_registration_id=self.channelRegistrationId,
            to=[self.phone_number],
            media_uri=input_media_uri,
        )

        # calling send() with whatsapp image message
        message_responses = messaging_client.send(image_message_options)
        response = message_responses.receipts[0]
        
        if (response is not None):
            print("WhatsApp Video containing Message with message id {} was successfully sent to {}"
            .format(response.message_id, response.to))
        else:
            print("Message failed to send")

if __name__ == '__main__':
    messages = MessagesQuickstart()
    messages.send_template_message()
    messages.send_text_message()
    messages.send_image_message()
    messages.send_document_message()
    messages.send_audio_message()
    messages.send_video_message()

Inne przykłady

Możesz przejrzeć i pobrać inne przykładowe kody dla zestawu SDK komunikatów języka Python w witrynie GitHub.

Następne kroki

W tym artykule opisano zestaw Advanced Messaging for WhatsApp SDK. Aby uzyskać więcej informacji, zobacz następujące artykuły: