Android SIP注册失败(-9 IN_PROGRESS)



这是我的注册代码:

    protected void initializeManagerOpen(){
    consoleWrite("initializeOpen");
    if(mSipManager==null) {
        return;
    }
    SipProfile.Builder builder;
    try {
        builder = new SipProfile.Builder("13", "10.0.0.4");
        builder.setPassword("13");
        builder.setPort(5062);
        builder.setProtocol("UDP");
        mSipProfile = builder.build();
        try {
            Intent intent = new Intent();
            intent.setAction("android.SipDemo.INCOMING_CALL");
            PendingIntent pendingIntent = PendingIntent.getBroadcast(mContext, 0, intent, Intent.FILL_IN_DATA);
            mSipManager.open(mSipProfile, pendingIntent, null);
            mSipManager.setRegistrationListener(mSipProfile.getUriString(), new SipRegistrationListener() {
                public void onRegistering(String localProfileUri) {
                    mNotificationTask.endNotification();
                    mNotificationTask.createNotification(R.drawable.ic_stat_connecting,"Test","Connecting");
                    consoleWrite("Registering with SIP Server...");
                }
                public void onRegistrationDone(String localProfileUri, long expiryTime){
                    mNotificationTask.endNotification();
                    mNotificationTask.createNotification(R.drawable.ic_stat_connected,"Test","Connected");
                    consoleWrite("Ready");
                }
                public void onRegistrationFailed(String localProfileUri, int errorCode, String errorMessage){
                    mNotificationTask.endNotification();
                    mNotificationTask.createNotification(R.drawable.ic_stat_disconnected,"Test","Failed to connect:"+errorCode);
                    consoleWrite("Registration failed.  Please check settings.");
                    consoleWrite(""+errorCode);
                    consoleWrite(errorMessage);
                }
            });
        } catch (SipException e) {
            e.printStackTrace();
        }
    } catch (ParseException e) {
        e.printStackTrace();
    }
}

虽然有时它注册成功,但大多数时候我都会收到一个错误代码-9:

Registration failed.  Please check settings.
-9
0

我在参考网站上找到了这个描述:

public static final int IN_PROGRESS
The client is in a transaction and cannot initiate a new one.
Constant Value: -9 (0xfffffff7)

它到底意味着什么?我的手机上没有运行任何其他SIP应用程序。

PS。当我第一次尝试连接时,它是有效的。但第二次是-9。也许我没有正确关闭连接?我想我有问题,因为我试图关闭连接,但它没有关闭

public void closeLocalProfile() {
    if(mSipManager==null){
        return;
    }
    try{
        if(mSipProfile!=null){
            mSipManager.close(mSipProfile.getUriString());
            consoleWrite("mSipManager Closed - "+mSipProfile.getUriString());
        }
    }catch(Exception e){
        consoleWrite("Failed to close local profile. - "+e);
    }
}

从Call Parameter中删除所有SIP帐户并重试:

呼叫应用->参数->呼叫账户互联网删除所有账户

PS:很抱歉出现名称菜单,我的手机不是英文

我也遇到过同样的问题,zicos22的评论帮助我解决了这个问题。这个问题是由于未关闭的SipProfiles引起的,所以你需要在onPause()方法中运行closeLocalProfile()(在onDestroy()中调用时不起作用)。事实上,我想我必须在单独的线程中运行这个sip内容,但现在我只是在onPause中关闭配置文件。在我的ZenUI安卓手机上,我可以在设置->呼叫设置->电话帐户设置->sip帐户中手动关闭当前打开的sip配置文件。

相关内容

最新更新