以编程方式在我的网络上呼叫我的VoIP电话

时间:2013-05-30 23:57:03

标签: java sip mjsip

这是环境: 我们的网络上有PC和Cisco VoIP电话。网络上有一个电话交换机,允许VoIP电话呼叫,但我不认为交换机与项目的这一部分相关。

这是我第一次将VoIP纳入我的软件,所以我试着让我的PC拨打我的VoIP电话。从PC上,我可以ping通手机的IP地址并得到回复,所以我应该可以与它通信。

到目前为止,我一直希望电话会响起。我在Java中使用mjsip,我收到一条呼叫失败的消息,原因是“请求超时”而没有响铃。关于电话接听后会发生什么,我还没有完成任何代码,但我想至少让它响个不停。

我希望有更多VoIP经验的人可以验证或排除我这样做不正确,或者可能会带来更多陷阱。例如,我甚至可以期待手机只是因为它是一部VoIP电话而响应一个SIP呼叫?即使它是同一网络上的VoIP电话,我是否必须通过电话交换机?这只是我的代码的问题吗?

代码,假设我已经正确完成,正在启动一个SIP堆栈,设置一个用户配置文件,并尝试拨打一个与该手机的IP和端口5060相对应的SIP地址(Google告诉我sip端口)通常是5060)。

public class SIPTest implements UserAgentListener, SipProviderListener
{
    public static void main(String[] args)
    {
        if(!SipStack.isInit())
            SipStack.init();

        SipProvider sipProvider = new SipProvider("127.0.0.1", 5060);
        UserAgentProfile profile = new UserAgentProfile();
        profile.audio = true;
        profile.hangup_time = 10;
        profile.user = "testuser";
        profile.keepalive_time = 8000;

        final UserAgent userAgent = new UserAgent(sipProvider, profile, new     SIPTest());

        sipProvider.addPromiscuousListener(new SIPTest());
        userAgent.call(new NameAddress(new SipURL("172.16.1.250", 5060)));
        System.out.println("end ...");
    }


    /**
     * begin SipProviderListener
     **/

    public void onReceivedMessage(SipProvider sip_provider,
                    Message message)
    {
        if (message.isInfo())
        {
            System.out.println("Promisque onReceivedMessage ... message " + message.getMethodId().toString() + "\n body = " + message.getBody());
        }
    }

    /**
     * end SipProviderListener
     **/


    /**
     * begin UserAgentListener
     **/

    public void onUaCallAccepted(UserAgent arg0)
    {
        System.out.println("onUaCallAccepted ...");
    }

    public void onUaCallCancelled(UserAgent arg0)
    {
        System.out.println("onUaCallCancelled ...");
    }

    public void onUaCallClosed(UserAgent arg0)
    {
        System.out.println("onUaCallClosed ...");
    }

    public void onUaCallFailed(UserAgent arg0, String reason)
    {
        System.out.println("onUaCallFailed ...");
        System.out.println("\t" + arg0);
        System.out.println("\t" + reason);
    }

    public void onUaCallIncoming(UserAgent arg0,
                            NameAddress arg1, NameAddress arg2)
    {
        System.out.println("onUaCallIncoming ...");
        System.out.println("from " + arg2.toString());
        System.out.println("to " + arg1.toString());

        arg0.accept();
        System.out.println("Call accepted ...");
    }

    public void onUaCallProgress(UserAgent ua)
    {
        System.out.println("onUaCallProgress ...");
    }

    public void onUaCallRinging(UserAgent arg0)
    {
        System.out.println("onUaCallRinging ...");
    }

    public void onUaCallTransferred(UserAgent arg0)
    {
        System.out.println("onUaCallTrasferred ...");
    }

    public void onUaIncomingCall(UserAgent ua, NameAddress callee, NameAddress caller, Vector media_descs)
    {
        System.out.println("onUaIncomingCall ...");
    }

    public void onUaMediaSessionStarted(UserAgent ua, String type, String codec)
    {
        System.out.println("onUaMediaSessionStopped ...");
    }

    public void onUaMediaSessionStopped(UserAgent ua, String type)
    {
        System.out.println("onUaMediaSessionStopped ...");
    }

    public void onUaRegistrationFailed(UserAgent ua, String result)
    {
        System.out.println("onUaRegistrationFailed ...");
    }

    public void onUaRegistrationSucceeded(UserAgent ua, String result)
    {
        System.out.println("onUaRegistrationSucceeded ...");
    }

    /**
     * end UserAgent
     **/
}

如果我运行它,以下是我得到的输出。

ExtendedAudioSystem: Supported: PCM_SIGNED PCM_UNSIGNED ALAW ULAW PCM_SIGNED PCM
_UNSIGNED PCM_FLOAT
ExtendedAudioSystem: TargetDataLine: PCM_SIGNED 8000.0 Hz, 16 bit, mono, 2 bytes
/frame, little-endian
ExtendedAudioSystem: Supported: PCM_SIGNED PCM_UNSIGNED ALAW ULAW PCM_SIGNED PCM
_UNSIGNED PCM_FLOAT
ExtendedAudioSystem: SourceDataLine: PCM_SIGNED 8000.0 Hz, 16 bit, mono, 2 bytes
/frame, little-endian
end ...
onUaCallFailed ...
        local.ua.UserAgent@283bbb6
        Request Timeout

1 个答案:

答案 0 :(得分:1)

在我看来,底层的SIP INVITE消息(对应于userAgent.call)被认为是由sip堆栈发送的,但是没有接收到应答。因此,您得到此(408)“请求超时”消息。 408请求超时是当没有从远程方(或代理)接收到响应时由sip堆栈自动生成的SIP响应。有时,由于一些奇怪的原因,防火墙可以阻止传出请求,并且不会通知java发送数据包时发生问题。因此,不会抛出异常,应用程序(此处为sip stack)无法再次发送数据包,也无法通知用户网络问题。

您是否检查过您可以使用同一主机上的另一个SIP客户端调用sip:172.16.1.250?您可以使用sipp快速测试(使用选项-m 1仅启动一个呼叫)。 如果您可以使用其他SIP客户端发出呼叫,则表示没有防火墙问题。