Compartilhar via


Executar novos eventos em segundo plano recebidos por SMS

A plataforma de SMS de Banda Larga Móvel fornece eventos de sistema separados para novos dados sms recebidos, dependendo se é uma notificação de SMS administrativa de uma operadora de rede móvel ou uma mensagem SMS geral. O evento de sistema em segundo plano para uma nova notificação de SMS administrativa recebida de uma operadora de rede móvel só é acessível por um aplicativo de banda larga móvel.

Os aplicativos já devem ter recebido o consentimento do usuário para usar o SMS para ler novas mensagens SMS recebidas em tarefas em segundo plano. Os aplicativos não poderão ler o conteúdo de uma nova mensagem SMS recebida de uma tarefa em segundo plano se estiverem acessando o SMS pela primeira vez, porque o aplicativo não pode disparar o prompt de consentimento do dispositivo SMS do sistema de uma tarefa em segundo plano.

Os exemplos de código a seguir demonstram uma tarefa em segundo plano projetada para ser executada quando uma nova mensagem SMS é recebida.

Código da tarefa em segundo plano do C#

namespace SmsBackgroundSample
{
  public sealed class SmsBackgroundTask : IBackgroundTask
  { 
    // The Run method is the entry point of a background task.

    public void Run(IBackgroundTaskInstance taskInstance)
    {
      // Associate a cancellation handler with the background task.

      taskInstance.Canceled += new BackgroundTaskCanceledEventHandler(OnCanceled);

      ManualResetEvent manualEventWaiter = new ManualResetEvent(false);
      manualEventWaiter.Reset();

      // Do the background task activity.

      DisplayToastAsync(taskInstance, manualEventWaiter);

      // Wait until the async operation is done. We need to do this else the background process will exit.
      manualEventWaiter.WaitOne(5000);

            Debug.Print("Background " + taskInstance.Task.Name + (" process ran"));

  }

  async void DisplayToastAsync(IBackgroundTaskInstance taskInstance, ManualResetEvent manualEventWaiter)
  {
    SmsReceivedEventDetails smsDetails = (SmsReceivedEventDetails)taskInstance.TriggerDetails;
    SmsBinaryMessage smsEncodedmsg = (SmsBinaryMessage) smsDetails.BinaryMessageMessage;
    SmsTextMessage smsTextMessage = Windows.Devices.Sms.SmsTextMessage.FromBinaryMessage(smsEncodedmsg);

    XmlDocument toastXml = ToastNotificationManager.GetTemplateContent(ToastTemplateType.ToastText02);
    XmlNodeList stringElements = toastXml.GetElementsByTagName("text");

    stringElements.Item(0).AppendChild(toastXml.CreateTextNode(smsTextMessage.From));
    stringElements.Item(1).AppendChild(toastXml.CreateTextNode(smsTextMessage.Body));

    ToastNotification notification = new ToastNotification(toastXml);
    ToastNotificationManager.CreateToastNotifier().Show(notification);

    manualEventWaiter.Set();
  }

}

Código do aplicativo JavaScript para registrar a tarefa em segundo plano

var triggerAway = new Windows.ApplicationModel.Background.SystemTrigger(Windows.ApplicationModel.Background.SystemTriggerType.smsReceived, false);
var builderAway = new Windows.ApplicationModel.Background.BackgroundTaskBuilder();

builderAway.setTrigger(triggerAway);
builderAway.taskEntryPoint = "HelloWorldBackground.BackgroundTask1";
builderAway.name = "Sms";

var taskAway = builderAway.register();
taskAway.addEventListener("progress", new ProgressHandler(taskAway).onProgress);
taskAway.addEventListener("completed", new CompleteHandler(taskAway).onCompleted);

Desenvolvendo aplicativos SMS