这是环境: 我们的网络上有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
答案 0 :(得分:1)
在我看来,底层的SIP INVITE消息(对应于userAgent.call)被认为是由sip堆栈发送的,但是没有接收到应答。因此,您得到此(408)“请求超时”消息。 408请求超时是当没有从远程方(或代理)接收到响应时由sip堆栈自动生成的SIP响应。有时,由于一些奇怪的原因,防火墙可以阻止传出请求,并且不会通知java发送数据包时发生问题。因此,不会抛出异常,应用程序(此处为sip stack)无法再次发送数据包,也无法通知用户网络问题。
您是否检查过您可以使用同一主机上的另一个SIP客户端调用sip:172.16.1.250?您可以使用sipp快速测试(使用选项-m 1仅启动一个呼叫)。 如果您可以使用其他SIP客户端发出呼叫,则表示没有防火墙问题。