JAIN-SIP RINGING Ответ никогда не отправляется - PullRequest
1 голос
/ 22 декабря 2010

Я создаю класс, который реализует интерфейс SipListener для получения событий из стека JAIN-SIP (для устройства Android). Чтобы проверить это, я подключаю 2 устройства к OpenSIP, и одно пытается вызвать другое. У меня нет проблем с использованием сторонних клиентов.

С моей базовой реализацией все работает хорошо, за исключением одной странной проблемы. Когда я получаю запрос INVITE в processRequest, я создаю ответ 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.x.x.x - IP-адрес OpenSIP, а 10.x.x.10 - IP-адрес UAC.

Я пропустил заголовок или неправильно настроил пакет RINGING? Любая помощь с благодарностью!

1 Ответ

0 голосов
/ 07 января 2011

Я думаю, что это не вызываемый абонент, который отправляет пробное сообщение, а opensips, который отправляет сообщение, которое он должен отправить при попытке связаться с вызываемым. и я почти уверен, что звонящее сообщение не отправляется, потому что вы не установили для него заголовок.

...