来自浏览器的 Twilio 拨出电话

标签 twilio twilio-api twilio-php twilio-click-to-call

我是 twilio 的初学者。我已阅读快速入门以从浏览器拨出电话。我的代码如下

 <?php
require 'twilio-php-master/Twilio/autoload.php';
use Twilio\Jwt\ClientToken;
$accountSid = '***************************';
$authToken  = '***************************';
$appSid = '****************';

$capability = new ClientToken($accountSid, $authToken);
$capability->allowClientOutgoing($appSid);
$capability->allowClientIncoming('jenny');
$token = $capability->generateToken();
?>

<!DOCTYPE html>
<html>
  <head>
    <title>Hello Client Monkey 4</title>
    <script type="text/javascript"
      src="//media.twiliocdn.com/sdk/js/client/v1.3/twilio.min.js"></script>
    <script type="text/javascript"
      src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js">
    </script>
    <link href="//static0.twilio.com/resources/quickstart/client.css"
      type="text/css" rel="stylesheet" />
    <script type="text/javascript">

      Twilio.Device.setup("<?php echo $token; ?>");

      Twilio.Device.ready(function (device) {
        $("#log").text("Ready");
      });

      Twilio.Device.error(function (error) {
        $("#log").text("Error: " + error.message);
      });

      Twilio.Device.connect(function (conn) {
        $("#log").text("Successfully established call");
      });

      Twilio.Device.disconnect(function (conn) {
        $("#log").text("Call ended");
      });

      Twilio.Device.incoming(function (conn) {
        $("#log").text("Incoming connection from " + conn.parameters.From);
        // accept the incoming connection and start two-way audio
        conn.accept();
      });

      function call() {
        // get the phone number to connect the call to
        params = {"PhoneNumber": $("#number").val()};
        Twilio.Device.connect(params);
      }

      function hangup() {
        Twilio.Device.disconnectAll();
      }
    </script>
  </head>
  <body>
    <button class="call" onclick="call();">
      Call
    </button>

    <button class="hangup" onclick="hangup();">
      Hangup
    </button>

    <input type="text" id="number" name="number"
      placeholder="Enter a phone number to call"/>

    <div id="log">Loading pigeons...</div>
  </body>
</html>

TwiML 代码在这里
<?xml version="1.0" encoding="UTF-8"?>
<Response>
  <Dial callerId="+14159426198">
    <Number>+91**********</Number>
  </Dial>
</Response>

我可以拨出电话。我已经使用上面的 twiML bin 制作了 TwiML 应用程序,但在 twiML 中拨出电话号码是静态的。如何使其动态调用任意号码的电话?

请帮忙。

最佳答案

Twilio 开发人员布道者在这里。

您已经设置了可以调用任何号码的 UI,您唯一需要做的就是使您的 TwiML 应用程序动态化。您可以看到,当您开始与客户端通话时,您正在发送一些参数:

  function call() {
    // get the phone number to connect the call to
    params = {"PhoneNumber": $("#number").val()};
    Twilio.Device.connect(params);
  }

当 Twilio 收到此调用时,它会将参数发送到您的 TwiML 应用程序,然后根据 TwiML 进行调用。您需要更新基于 PhoneNumber 动态生成的 TwiML您发送的参数。这样的事情应该工作:
<?php
  $phoneNumber = $_REQUEST['PhoneNumber'];
  header("Content-type: text/xml");
?>
<Response>
  <Dial callerId="+14159426198">
    <Number><?php echo $phoneNumber ?></Number>
  </Dial>
</Response>

让我知道这是否有帮助。

关于来自浏览器的 Twilio 拨出电话,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46608303/

相关文章:

sms - 您可以通过 Twilio 发送富文本消息吗?

Twilio 获取传入的 SMS 消息(没有 webhook)

Twilio 发送消息 API 错误 21603

java - 成功后如何从 Parse Cloud 将验证码发送回我的应用程序?

php - Twilio 可编程语音通话 android

php - 使用 PHP54 和 Twilio 发送消息时出现 Http 500 错误

javascript - 使用 Twilio 进行视频通话

twilio - 在 twilio 中未注册的两个号码之间调用电话

c# - 异常绑定(bind)参数 'message'

java - 无法在 Twilio 中发送短信