簡體   English   中英

Twilio iOS SDK在撥出電話時失敗並顯示“400 Bad request”

[英]Twilio iOS SDK fails with “400 Bad request” on outgoing call

獲取此處提供的示例源代碼,轉換為Swift 3並應用我生成的升級后的Twilio帳戶令牌。

嘗試撥打電話時,它會播放聲音,但在嘗試訪問https://matrix.twilio.com/2012-02-09/AC ...時,會因HTTP/1.0 400 Bad request失敗。

這是試圖打電話后的日志 -

2016-10-16 18:32:12.955056 MyApp[577:121739] [DEBUG TCDeviceInternal] Inside TCDeviceInternal initWithCapabilityToken, capabilityToken_: (null)
2016-10-16 18:32:12.961112 MyApp[577:121739] [VERBOSE TCDeviceInternal] Inside decodeCapabilityToken:, Header: {
    alg = HS256;
    typ = JWT;
}
2016-10-16 18:32:12.962305 MyApp[577:121739] [VERBOSE TCDeviceInternal] Inside decodeCapabilityToken:, payload: {
    exp = 1476635532;
    iss = ....REMOVED....................;
    scope = "scope:client:incoming?clientName=TestName scope:client:outgoing?appSid=AP.....REMOVED......&clientName=TestName";
}
2016-10-16 18:32:12.962611 MyApp[577:121739] [VERBOSE TCDeviceInternal] Scope URI: scope:client:incoming?clientName=TestName, inside setCapabilitiesWithCapabilityToken:
2016-10-16 18:32:12.962860 MyApp[577:121739] [VERBOSE TCDeviceInternal] Scope URI: scope:client:outgoing?appSid=AP.............REMOVED.......&clientName=TestName, inside setCapabilitiesWithCapabilityToken:
2016-10-16 18:32:12.963710 MyApp[577:121739] [DEBUG TCConstants] X-Twilio-Client string: {"p":"ios","v":"1.2.7.b99-1015b1f","mobile":{"arch":"unknown type 16777228 subtype 1","product":"iPhone","name":"iPhone8,4","v":"10.0.2"}}, inside TCConstants clientString
2016-10-16 18:32:13.035381 MyApp[577:121739] [VERBOSE Twilio] Inside initWithConfig:, codec: speex/16000/1 -> priority: 255
2016-10-16 18:32:13.035425 MyApp[577:121739] [VERBOSE Twilio] Inside initWithConfig:, codec: speex/8000/1 -> priority: 254
2016-10-16 18:32:13.035457 MyApp[577:121739] [VERBOSE Twilio] Inside initWithConfig:, codec: speex/32000/1 -> priority: 0
2016-10-16 18:32:13.035500 MyApp[577:121739] [VERBOSE Twilio] Inside initWithConfig:, codec: opus/48000/1 -> priority: 0
2016-10-16 18:32:13.035574 MyApp[577:121739] [VERBOSE Twilio] Inside initWithConfig:, codec: PCMU/8000/1 -> priority: 128
2016-10-16 18:32:13.035669 MyApp[577:121739] [VERBOSE Twilio] Inside initWithConfig:, codec: PCMA/8000/1 -> priority: 0
2016-10-16 18:32:13.035843 MyApp[577:121739] [DEBUG Twilio] Inside startStateNotificationsForObject, delegate: <TCDeviceInternal: 0x17018c710>
2016-10-16 18:32:13.036069 MyApp[577:121739] [VERBOSE Twilio] Inside addUserAccount:, Registration URL: sip:TestName@chunderm.gll.twilio.com;transport=tls
2016-10-16 18:32:13.037112 MyApp[577:121739] [DEBUG TwilioReachability] Reachability Flag Status: -R ------- networkStatusForFlags
2016-10-16 18:32:13.037191 MyApp[577:121739] [DEBUG TCDeviceInternal] Internet reachability: 1
2016-10-16 18:32:13.037434 MyApp[577:121739] [DEBUG TCDeviceInternal] Created TCDeviceInternal: <TCDeviceInternal: 0x17018c710> for accountId: 0
2016-10-16 18:32:13.038306 MyApp[577:121739] [DEBUG TCHttpJsonLongPollConnection] Inside TCHTTPJSONLongPollConnection run(), gonna connect to host matrix.twilio.com, port 443
2016-10-16 18:32:13.039266 MyApp[577:121739] [DEBUG TCHttpJsonLongPollConnection] Inside onSocketWillConnect, sock: <TCAsyncSocket 0x17418ddd0 local nowhere remote nowhere has queued 0 reads 0 writes, no current read, no current write, read stream 0x17010d260 not open, write stream 0x1701065d0 not open, not connected>, self: <TCHttpJsonLongPollConnection 0x1740aa9e0 url=https://matrix.twilio.com/2012-02-09/.........REMOVED............../TestName?AccessToken=...............REMOVED......................&feature=publishPresence&feature=presenceEvents connected=0 https=1>
2016-10-16 18:32:13.052355 MyApp[577:121739] [DEBUG TCSoundManager] TCSoundManager: sharedInstance: 0x0
2016-10-16 18:32:13.052423 MyApp[577:121739] [DEBUG TCSoundManager] TCSoundManager init, top
2016-10-16 18:32:13.052461 MyApp[577:121739] [VERBOSE TCSoundManager] TCSoundManager init, starting
2016-10-16 18:32:13.109491 MyApp[577:121739] [DEBUG TCSoundManager] TCSoundManager: player configured
2016-10-16 18:32:13.120029 MyApp[577:121739] [VERBOSE TCSoundManager] TCSoundManager init, done
2016-10-16 18:32:13.120917 MyApp[577:121739] [DEBUG TCSoundManager] TCSoundManager: attempting to play item, (inside TCSoundManager play())
2016-10-16 18:32:13.121720 MyApp[577:121739] [DEBUG TCSoundManager] Player status: 0, inside observeValueForKeyPath:
[2016-10-16 18:32:13.123] Caller.swift:55 DEBUG: Twilio connection created successfully
2016-10-16 18:32:13.136004 MyApp[577:121739] [DEBUG TCSoundManager] Player status: 1, inside observeValueForKeyPath:
2016-10-16 18:32:13.145341 MyApp[577:121739] [DEBUG TCSoundManager] Item status: 1, inside observeValueForKeyPath:
2016-10-16 18:32:13.226409 MyApp[577:121739] [DEBUG TCHttpJsonLongPollConnection] Inside beginning of onSocket:didConnectToHost
2016-10-16 18:32:13.226632 MyApp[577:121739] [DEBUG TCHttpJsonLongPollConnection] Starting TLS with settings:
{
    kCFStreamSSLPeerName = "*.twilio.com";
    kCFStreamSSLValidatesCertificateChain = 1;
    kCFStreamSocketSecurityLevelNegotiatedSSL = kCFStreamPropertySocketSecurityLevel;
}, inside onSocket:didConnectToHost:
2016-10-16 18:32:13.227088 MyApp[577:121739] [DEBUG TCEventStream] Inside longPollConnectionDidConnect:, stream <TCEventStream: 0x17427cbc0> connected
2016-10-16 18:32:13.227331 MyApp[577:121739] [DEBUG TCHttpJsonLongPollConnection] REQUEST: URL: https://matrix.twilio.com/2012-02-09/.............REMOVED............/TestName?AccessToken=..........................................REMOVED..................................&feature=publishPresence&feature=presenceEvents   GET /2012-02-09/........REMOVED............/ProjectName App?AccessToken=................................REMOVED....................................&feature=publishPresence&feature=pres
2016-10-16 18:32:14.028697 MyApp[577:121739] [DEBUG TCHttpJsonLongPollConnection] Inside beginning of onSocket:didReadData
2016-10-16 18:32:14.028836 MyApp[577:121739] [VERBOSE TCHttpJsonLongPollConnection] Received 
HTTP/1.0 400 Bad request
Cache-Control: no-cache
Connection: close
Content-Type: text/html

, inside onSocket:didReadData
2016-10-16 18:32:14.029065 MyApp[577:121739] [DEBUG TCEventStream] Inside longPollConnection:didReceiveHeaders:, stream <TCEventStream: 0x17427cbc0> got headers
2016-10-16 18:32:14.030074 MyApp[577:121739] [DEBUG TCEventStream] Inside longPollConnection:didFailWithError:, stream <TCEventStream: 0x17427cbc0> disconnected, error Error Domain=com.twilio.client.TCHttpErrorDomain Code=4 "HTTP server returned non-success status" UserInfo={com.twilio.client.TCHttpStatusCodeKey=400, NSLocalizedDescription=HTTP server returned non-success status}
2016-10-16 18:32:15.017604 MyApp[577:121739] [INFO TCSoundManager] TCSoundManager: playerItemDidReachEnd: 7466A900, (inside playerItemDidReachEnd)
2016-10-16 18:32:15.017913 MyApp[577:121739] [DEBUG TCCommandHandler] Inside postCommand:, received command of type TCMakeCallCommand
2016-10-16 18:32:15.018535 MyApp[577:121739] [DEBUG TCSoundManager] Player status: 1, inside observeValueForKeyPath:
2016-10-16 18:32:21.396771 MyApp[577:121739] [DEBUG Twilio] Application is in background
2016-10-16 18:32:21.397023 MyApp[577:121739] Legacy VoIP background mode is deprecated and no longer supported

可能是什么問題?

很難看到代碼(使用您輸入的參數)來確定真正的問題是什么。 但是我會努力的。 您的日志文件中有兩個問題:

  1. 400 BAD REQUEST意味着:HTTP POSTPUT給出的數據驗證失敗。
  2. longPollConnection : didFailWithError表示:服務器不可用,不響應和/或發送新信息。 --------------------------------------------

     2016-10-16 18:32:14.030074 MyApp[577:121739] [DEBUG TCEventStream] Inside longPollConnection:didFailWithError:, stream <TCEventStream: 0x17427cbc0> disconnected, error Error Domain=com.twilio.client.TCHttpErrorDomain Code=4 "HTTP server returned non-success status" UserInfo={com.twilio.client.TCHttpStatusCodeKey=400, NSLocalizedDescription=HTTP server returned non-success status} 

以下是可能的解決方案:

  1. 重置Xcode和iOS模擬器: 如何重置Xcode和iOS模擬器SO帖子

  2. 如果有必要,請更新Podfile: Pod安裝與pod更新

  3. 閱讀有關可能出現的問題的文章: 什么是HTTP長輪詢?

  4. 觀看此有用視頻: 高級調試和地址清理程序

  5. 仔細檢查這些參數: 語音:Twilio的請求

  6. 如果您正在編寫自己的客戶端 ,則需要將HTTP Content-Type標頭設置為application/x-www-form-urlencoded以滿足您的請求。

  7. 您應該檢查response正文以獲取詳細信息。

還有其他有用的參考:

使用twilio無法正常發送短信

Twilio:REST API:撥打電話

希望這可以幫助!

在iOS 10中,您應該使用PushKit來處理傳入VoIP呼叫的推送通知。 因此,當您針對iOS 10 SDK構建應用程序時,您需要轉移到PushKit(可以一直支持iOS 8,但是一旦轉移到iOS 10,我們的建議是將您的最低部署目標更新到iOS 9)。

我相信您最好的選擇是更新到Programmable TwilioVoice SDK以避免將來出現此類問題,我們開始在使用TwilioClient的應用程序中遇到類似的問題。 Twilio已停止支持TwilioClient SDK。

請查看: https//www.twilio.com/docs/voice/client/ios

切換到最新的SDK需要從后端/前端進行一些更改,因為他們已經棄用了類,如TCDevice,TCConnection等。

如果我有所幫助,請告訴我。 祝好運。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM