我正在开发一个简单的应用程序,允许用户使用sip协议启动呼叫。 问题是在某些情况下无法创建SipSession(例如,删除具有活动sip会话的应用程序,并再次安装它)。
在这种情况下,我收到错误:
android.net.sip.SipException: Failed to create SipSession; network unavailable?
只有在物理设备重启后才能正常工作。
我的Sip课程:
public class SipDataManager {
private Context context;
private SipManager sipManager;
private SipProfile sipProfile;
private SipSession sipSession;
private UserProfile userProfile;
public SipDataManager(Context context, UserProfile userProfile) {
this.context = context;
this.userProfile = userProfile;
}
public void initialize() throws SipException {
Log.d("mylog", "initialize manager");
if (sipManager == null) {
Log.d("mylog", "sip manager is not null");
sipManager = SipManager.newInstance(context);
}
initializeProfile();
}
private void initializeProfile() throws SipException {
if (sipManager == null)
return;
if (sipProfile != null) {
close();
}
sipProfile = userProfile.build();
Intent intent = new Intent();
intent.setAction("ru.tenet.sipclient.INCOMING_CALL");
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, Intent.FILL_IN_DATA);
sipManager.open(sipProfile, pendingIntent, null);
sipSession = sipManager.createSipSession(sipProfile, new MySipSessionListener());
sipManager.setRegistrationListener(sipProfile.getUriString(), new MySipRegistrationListener());
}
public void close() {
try {
if (sipProfile != null) {
sipManager.close(sipProfile.getUriString());
}
} catch (Exception ee) {
Log.e("mylog", "Failed to close local profile.", ee);
}
}
//getters and setters
我试图删除此
sipSession = sipManager.createSipSession(sipProfile, new MySipSessionListener());
在这种情况下,我不会得到任何异常,但 SipRegistrationListener 回调将不会被调用。
只有重启才能帮助..
有人遇到过这个问题吗?我没有找到任何正确的解决方案..
解 问题出在我的设备或固件(三星Galaxy s4,Android 5.0.1官方,但一些集成的应用程序已删除root)。 使用带有cyanogen的Android 4.3.1检查三星Galaxy s4 - 没问题。
答案 0 :(得分:0)
在尝试打开配置文件以发送或接听电话之前创建您的SipSession。
sipSession = sipManager.createSipSession(sipProfile, new MySipSessionListener());
sipManager.open(sipProfile, pendingIntent, null);
答案 1 :(得分:0)
我遇到了同样的问题,无法以编程方式纠正它。当前的解决方案是添加一个10秒的延迟处理程序来检查OnRegistrationDone和OnRegistering事件是否在此期间被触发。以下代码紧跟在initializeLocalProfile函数中的manager.setRegistrationListener方法之前。检测到此错误情况时,将启动SIP首选项活动,并通过SIP库错误通知用户,请求他们重新启动设备。相同的处理程序还检测到连接到已定义的SIP服务器以及向用户发送“未找到服务器”通知的问题。这两种错误情况通常会触发“注册超时”错误,但您无法区分该事件中的两种错误类型,并且需要30秒才能超时。
if (!manager.isOpened(me.getUriString())) {
if (me_listener == null) {
manager.open(me, pi, null);
} else {
manager.open(me, pi, me_listener);
}
}
// This listener must be added AFTER manager.open is called,
// Otherwise the methods aren't guaranteed to fire.
if (me_listener == null) {
bConnecting = true;
final Handler handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
if (sentConnecting == false && bLocalOpen == false) { //never connected or connecting
updateStatus("SIP Library Error");
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getBaseContext());
SharedPreferences.Editor editor = prefs.edit();
editor.remove("namePref");
editor.remove("domainPref");
editor.putString("statusPref", "SIP Library Error - Please Restart Device and Try Again");
editor.commit();
updatePreferences();
return;
} else if (bConnecting == true && bLocalOpen == false) { //never connected
updateStatus("Server Not Found");
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getBaseContext());
SharedPreferences.Editor editor = prefs.edit();
editor.remove("namePref");
editor.remove("domainPref");
editor.putString("statusPref", "Server Not Found, Please Edit and Try Again");
editor.commit();
updatePreferences();
return;
}
}
}, 10000);