JAIN-SIP スタック (Android デバイス用) からイベントを受信する SipListener インターフェイスを実装するクラスを作成しています。テストするために、2 つのデバイスを OpenSIP に接続し、1 つのデバイスをもう 1 つのデバイスに呼び出してみました。サードパーティのクライアントを使用しても問題ありません。
1 つの奇妙な問題を除いて、すべてが私の基本的な実装でうまく機能しているようです。processRequest で INVITE リクエストを受信すると、RINGING レスポンスを作成し、続いて OK レスポンスを作成します。問題は、(tcpdump によると) RINGING 応答がサーバーに届かないことです。INVITE パケットを受信した後、デバイスは TRYING パケットを送信し (私のコードでは実行しないので、JAIN-SIP の一部である必要があります)、OK パケットを送信します。私はさまざまな例をたどりましたが、それらはすべてこれらの行に沿って何かを示唆しているようです:
//This function gets called from processRequest
//Some initialization code removed to keep this short
private void processInvite(RequestEvent requestEvent)
{
ServerTransaction serverTransaction = requestEvent.getServerTransaction();
SipProvider sipProvider = (SipProvider) requestEvent.getSource();
Request request = requestEvent.getRequest();
//Create RINGING response
Response response = m_messageFactory.createResponse(Response.RINGING,
request);
//Add a contact header
Address contactAddress = m_addressFactory
.createAddress(m_username + " <sip:" + getLocalIpAddress() + ":" + m_sipPort + ">");
ContactHeader contactHeader = m_headerFactory.createContactHeader(contactAddress);
response.addHeader(contactHeader);
if (serverTransaction == null)
{
serverTransaction = sipProvider.getNewServerTransaction(request);
}
//Send RINGING response
//This never makes it to the server
serverTransaction.sendResponse(response);
//Create OK response
Response okResponse = m_messageFactory.createResponse(Response.OK, request);
ToHeader toHeader = (ToHeader) okResponse.getHeader(ToHeader.NAME);
toHeader.setTag("4321");
okResponse.addHeader(contactHeader);
//Send OK Response
//This makes it to the server
serverTransaction.sendResponse(okResponse);
}
参考までに、INVITE ヘッダーは次のようになります。
INVITE sip:4321@64.x.x.x:5060 SIP/2.0
Call-ID: 25e87b79f720728c6676d492e10c5984@10.x.x.10
CSeq: 20 INVITE
From: "Caller" <sip:1234@64.x.x.x:5060>;tag=12345
To: "Callee" <sip:4321@64.x.x.x:5060>
Via: SIP/2.0/UDP 10.x.x.10:5060;branch=z9hG4bKe45cd7919b5177a806ec1a9238b841f9393739
Max-Forwards: 70
Contact: "4321" <sip:1234@10.x.x.10:5060>
Content-Length: 0
64.xxx は OpenSIP の IP で、10.xx10 は UAC の IP です。
ヘッダーがないか、RINGING パケットの設定が間違っていますか? どんな助けでも大歓迎です!