语音通知

本文为您展示了语音通知功能的实现方法。您可以通过调用SingleCallByVoice发起语音文件类型的语音通知,调用SingleCallByTts发起文本转语音类型的语音通知。

功能介绍

语音通知可解决通知到达率延迟、关注度不高、阅读体验差等问题,并且您可以通过电话获得更全面的信息通知。您只需要提前设置通知模板内容,调用API就可以给用户推送语音通知,并可以设置播放音量、播放次数等。

准备工作

在实现调用API实现语音通知功能前,您需要完成以下操作:

代码示例

本示例展示了如何调用SingleCallByVoice接口发送语音通知。

  • 调用SingleCallByVoice,向指定号码发送语音通知文件类型的语音通知。

  • 调用SingleCallByTts,向指定号码发送语音验证码或文本转语音类型的语音通知。

如果您需要进行调试,请参见使用OpenAPI Explorer

// This file is auto-generated, don't edit it. Thanks.
package com.aliyun.sample;

import com.aliyun.tea.*;
import com.aliyun.dyvmsapi20170525.*;
import com.aliyun.dyvmsapi20170525.models.*;
import com.aliyun.teaopenapi.*;
import com.aliyun.teaopenapi.models.*;

public class Sample {

    /**
     * 使用AK&SK初始化账号Client
     * @param accessKeyId
     * @param accessKeySecret
     * @return Client
     * @throws Exception
     */
    public static com.aliyun.dyvmsapi20170525.Client createClient(String accessKeyId, String accessKeySecret) throws Exception {
        Config config = new Config()
                // 您的AccessKey ID
                .setAccessKeyId(accessKeyId)
                // 您的AccessKey Secret
                .setAccessKeySecret(accessKeySecret);
        // 访问的域名
        config.endpoint = "dyvmsapi.aliyuncs.com";
        return new com.aliyun.dyvmsapi20170525.Client(config);
    }

    public static void main(String[] args_) throws Exception {
        java.util.List<String> args = java.util.Arrays.asList(args_);
        com.aliyun.dyvmsapi20170525.Client client = Sample.createClient("accessKeyId", "accessKeySecret");
        SingleCallByVoiceRequest singleCallByVoiceRequest = new SingleCallByVoiceRequest()
                .setCalledShowNumber("05710000****")
                .setCalledNumber("1860000****")
                .setVoiceCode("e271f3f2-e155-4366-a9f4-0fe55765****.wav");
        // 复制代码运行请自行打印 API 的返回值
        client.singleCallByVoice(singleCallByVoiceRequest);
    }
}
# -*- coding: utf-8 -*-
# This file is auto-generated, don't edit it. Thanks.
import sys

from typing import List

from alibabacloud_dyvmsapi20170525.client import Client as Dyvmsapi20170525Client
from alibabacloud_tea_openapi import models as open_api_models
from alibabacloud_dyvmsapi20170525 import models as dyvmsapi_20170525_models


class Sample:
    def __init__(self):
        pass

    @staticmethod
    def create_client(
        access_key_id: str,
        access_key_secret: str,
    ) -> Dyvmsapi20170525Client:
        """
        使用AK&SK初始化账号Client
        @param access_key_id:
        @param access_key_secret:
        @return: Client
        @throws Exception
        """
        config = open_api_models.Config(
            # 您的AccessKey ID,
            access_key_id=access_key_id,
            # 您的AccessKey Secret,
            access_key_secret=access_key_secret
        )
        # 访问的域名
        config.endpoint = 'dyvmsapi.aliyuncs.com'
        return Dyvmsapi20170525Client(config)

    @staticmethod
    def main(
        args: List[str],
    ) -> None:
        client = Sample.create_client('accessKeyId', 'accessKeySecret')
        single_call_by_voice_request = dyvmsapi_20170525_models.SingleCallByVoiceRequest(
            called_show_number='05710000****',
            called_number='1860000****',
            voice_code='e271f3f2-e155-4366-a9f4-0fe55765****.wav'
        )
        # 复制代码运行请自行打印 API 的返回值
        client.single_call_by_voice(single_call_by_voice_request)

    @staticmethod
    async def main_async(
        args: List[str],
    ) -> None:
        client = Sample.create_client('accessKeyId', 'accessKeySecret')
        single_call_by_voice_request = dyvmsapi_20170525_models.SingleCallByVoiceRequest(
            called_show_number='05710000****',
            called_number='1860000****',
            voice_code='e271f3f2-e155-4366-a9f4-0fe55765****.wav'
        )
        # 复制代码运行请自行打印 API 的返回值
        await client.single_call_by_voice_async(single_call_by_voice_request)


if __name__ == '__main__':
    Sample.main(sys.argv[1:])
// This file is auto-generated, don't edit it. Thanks.
package main

import (
  "os"
  dyvmsapi20170525  "github.com/alibabacloud-go/dyvmsapi-20170525/v3/client"
  openapi  "github.com/alibabacloud-go/darabonba-openapi/v2/client"
  util  "github.com/alibabacloud-go/tea-utils/v2/service"
  "github.com/alibabacloud-go/tea/tea"
)


/**
 * 使用AK&SK初始化账号Client
 * @param accessKeyId
 * @param accessKeySecret
 * @return Client
 * @throws Exception
 */
func CreateClient (accessKeyId *string, accessKeySecret *string) (_result *dyvmsapi20170525.Client, _err error) {
  config := &openapi.Config{
    // 必填,您的 AccessKey ID
    AccessKeyId: accessKeyId,
    // 必填,您的 AccessKey Secret
    AccessKeySecret: accessKeySecret,
  }
  // 访问的域名
  config.Endpoint = tea.String("dyvmsapi.aliyuncs.com")
  _result = &dyvmsapi20170525.Client{}
  _result, _err = dyvmsapi20170525.NewClient(config)
  return _result, _err
}

func _main (args []*string) (_err error) {
  // 初始化 Client,采用 AK&SK 鉴权访问的方式,此方式可能会存在泄漏风险,建议使用 STS 方式。鉴权访问方式请参考:https://help.aliyun.com/document_detail/378661.html
  // 获取 AK 链接:https://usercenter.console.aliyun.com
  client, _err := CreateClient(tea.String("accessKeyId"), tea.String("accessKeySecret"))
  if _err != nil {
    return _err
  }

  singleCallByVoiceRequest := &dyvmsapi20170525.SingleCallByVoiceRequest{
    CalledShowNumber: tea.String("05710000****"),
    CalledNumber: tea.String("1860000****"),
    VoiceCode: tea.String("e271f3f2-e155-4366-a9f4-0fe55765****.wav"),
  }
  runtime := &util.RuntimeOptions{}
  tryErr := func()(_e error) {
    defer func() {
      if r := tea.Recover(recover()); r != nil {
        _e = r
      }
    }()
    // 复制代码运行请自行打印 API 的返回值
    _, _err = client.SingleCallByVoiceWithOptions(singleCallByVoiceRequest, runtime)
    if _err != nil {
      return _err
    }

    return nil
  }()

  if tryErr != nil {
    var error = &tea.SDKError{}
    if _t, ok := tryErr.(*tea.SDKError); ok {
      error = _t
    } else {
      error.Message = tea.String(tryErr.Error())
    }
    // 如有需要,请打印 error
    _, _err = util.AssertAsString(error.Message)
    if _err != nil {
      return _err
    }
  }
  return _err
}


func main() {
  err := _main(tea.StringSlice(os.Args[1:]))
  if err != nil {
    panic(err)
  }
}
<?php

// This file is auto-generated, don't edit it. Thanks.
namespace AlibabaCloud\SDK\Sample;

use AlibabaCloud\SDK\Dyvmsapi\V20170525\Dyvmsapi;

use Darabonba\OpenApi\Models\Config;
use AlibabaCloud\SDK\Dyvmsapi\V20170525\Models\SingleCallByVoiceRequest;

class Sample {

    /**
     * 使用AK&SK初始化账号Client
     * @param string $accessKeyId
     * @param string $accessKeySecret
     * @return Dyvmsapi Client
     */
    public static function createClient($accessKeyId, $accessKeySecret){
        $config = new Config([
            // 您的AccessKey ID
            "accessKeyId" => $accessKeyId,
            // 您的AccessKey Secret
            "accessKeySecret" => $accessKeySecret
        ]);
        // 访问的域名
        $config->endpoint = "dyvmsapi.aliyuncs.com";
        return new Dyvmsapi($config);
    }

    /**
     * @param string[] $args
     * @return void
     */
    public static function main($args){
        $client = self::createClient("accessKeyId", "accessKeySecret");
        $singleCallByVoiceRequest = new SingleCallByVoiceRequest([
            "calledShowNumber" => "05710000****",
            "calledNumber" => "1860000****",
            "voiceCode" => "e271f3f2-e155-4366-a9f4-0fe55765****.wav"
        ]);
        // 复制代码运行请自行打印 API 的返回值
        $client->singleCallByVoice($singleCallByVoiceRequest);
    }
}
$path = __DIR__ . \DIRECTORY_SEPARATOR . '..' . \DIRECTORY_SEPARATOR . 'vendor' . \DIRECTORY_SEPARATOR . 'autoload.php';
if (file_exists($path)) {
    require_once $path;
}
Sample::main(array_slice($argv, 1));
// This file is auto-generated, don't edit it. Thanks.

using System;
using System.Collections;
using System.Collections.Generic;
using System.IO;
using System.Threading.Tasks;

using Tea;
using Tea.Utils;


namespace AlibabaCloud.SDK.Sample
{
    public class Sample 
    {

        /**
         * 使用AK&SK初始化账号Client
         * @param accessKeyId
         * @param accessKeySecret
         * @return Client
         * @throws Exception
         */
        public static AlibabaCloud.SDK.Dyvmsapi20170525.Client CreateClient(string accessKeyId, string accessKeySecret)
        {
            AlibabaCloud.OpenApiClient.Models.Config config = new AlibabaCloud.OpenApiClient.Models.Config
            {
                // 您的AccessKey ID
                AccessKeyId = accessKeyId,
                // 您的AccessKey Secret
                AccessKeySecret = accessKeySecret,
            };
            // 访问的域名
            config.Endpoint = "dyvmsapi.aliyuncs.com";
            return new AlibabaCloud.SDK.Dyvmsapi20170525.Client(config);
        }

        public static void Main(string[] args)
        {
            AlibabaCloud.SDK.Dyvmsapi20170525.Client client = CreateClient("accessKeyId", "accessKeySecret");
            AlibabaCloud.SDK.Dyvmsapi20170525.Models.SingleCallByVoiceRequest singleCallByVoiceRequest = new AlibabaCloud.SDK.Dyvmsapi20170525.Models.SingleCallByVoiceRequest
            {
                CalledShowNumber = "05710000****",
                CalledNumber = "1860000****",
                VoiceCode = "e271f3f2-e155-4366-a9f4-0fe55765****.wav",
            };
            // 复制代码运行请自行打印 API 的返回值
            client.SingleCallByVoice(singleCallByVoiceRequest);
        }


    }
}
// This file is auto-generated, don't edit it
import Dyvmsapi20170525, * as $Dyvmsapi20170525 from '@alicloud/dyvmsapi20170525';
// 依赖的模块可通过下载工程中的模块依赖文件或右上角的获取 SDK 依赖信息查看
import OpenApi, * as $OpenApi from '@alicloud/openapi-client';
import * as $tea from '@alicloud/tea-typescript';


export default class Client {

  /**
   * 使用AK&SK初始化账号Client
   * @param accessKeyId
   * @param accessKeySecret
   * @return Client
   * @throws Exception
   */
  static createClient(accessKeyId: string, accessKeySecret: string): Dyvmsapi20170525 {
    let config = new $OpenApi.Config({
      // 您的AccessKey ID
      accessKeyId: accessKeyId,
      // 您的AccessKey Secret
      accessKeySecret: accessKeySecret,
    });
    // 访问的域名
    config.endpoint = "dyvmsapi.aliyuncs.com";
    return new Dyvmsapi20170525(config);
  }

  static async main(args: string[]): Promise<void> {
    let client = Client.createClient("accessKeyId", "accessKeySecret");
    let singleCallByVoiceRequest = new $Dyvmsapi20170525.SingleCallByVoiceRequest({
      calledShowNumber: "05710000****",
      calledNumber: "1860000****",
      voiceCode: "e271f3f2-e155-4366-a9f4-0fe55765****.wav",
    });
    // 复制代码运行请自行打印 API 的返回值
    await client.singleCallByVoice(singleCallByVoiceRequest);
  }

}

Client.main(process.argv.slice(2));

执行结果

正常返回结果如下所示:

{
  "Message": "OK",
  "RequestId": "4ABF7FB6-449C-4624-8CC6-9AAE3684****",
  "Code": "OK",
  "CallId": "1187209624900105518****"
}

调用SDK返回错误码,详情请参见错误码列表

阿里云首页 语音服务 相关技术圈