VOIP SipDemo 注册失败(错误)

Posted

技术标签:

【中文标题】VOIP SipDemo 注册失败(错误)【英文标题】:VOIP SipDemo Registration Failed (ERROR) 【发布时间】:2014-04-06 21:33:29 【问题描述】:

我正在制作一个具有 VOIP 的应用程序。

我已经证明了一些例子,但没有成功。

1 - 尝试使用 openfire

我正在使用 openfire,在配置 -> 服务器 -> 电话中,我有一些映射 SIP 帐户。

2 - 尝试使用 3cx(免费 sip 服务器)

我试过用android访问但没有成功:

这是我的代码(Android sip 演示) http://developer.android.com/guide/topics/connectivity/sip.html

用户 = 11 域:192.168.56.101 / 127.0.0.1 密码 = 11


总是注册失败。有什么想法吗?


public class WalkieTalkieActivity extends Activity implements View.OnTouchListener 

    public String sipAddress = null;

    public SipManager manager = null;
    public SipProfile me = null;
    public SipAudioCall call = null;
    public IncomingCallReceiver callReceiver;

    private static final int CALL_ADDRESS = 1;
    private static final int SET_AUTH_INFO = 2;
    private static final int UPDATE_SETTINGS_DIALOG = 3;
    private static final int HANG_UP = 4;


    @Override
    public void onCreate(Bundle savedInstanceState) 

        super.onCreate(savedInstanceState);
        setContentView(R.layout.walkietalkie);

        ToggleButton pushToTalkButton = (ToggleButton) findViewById(R.id.pushToTalk);
        pushToTalkButton.setOnTouchListener(this);

        // Set up the intent filter.  This will be used to fire an
        // IncomingCallReceiver when someone calls the SIP address used by this
        // application.
        IntentFilter filter = new IntentFilter();
        filter.addAction("android.SipDemo.INCOMING_CALL");
        callReceiver = new IncomingCallReceiver();
        this.registerReceiver(callReceiver, filter);

        // "Push to talk" can be a serious pain when the screen keeps turning off.
        // Let's prevent that.
        getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);

        initializeManager();
    

    @Override
    public void onStart() 
        super.onStart();
        // When we get back from the preference setting Activity, assume
        // settings have changed, and re-login with new auth info.
        initializeManager();
    

    @Override
    public void onDestroy() 
        super.onDestroy();
        if (call != null) 
            call.close();
        

        closeLocalProfile();

        if (callReceiver != null) 
            this.unregisterReceiver(callReceiver);
        
    

    public void initializeManager() 
        if(manager == null) 
          manager = SipManager.newInstance(this);
        

        initializeLocalProfile();
    

    /**
     * Logs you into your SIP provider, registering this device as the location to
     * send SIP calls to for your SIP address.
     */
    public void initializeLocalProfile() 
        if (manager == null) 
            return;
        

        if (me != null) 
            closeLocalProfile();
        

        SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getBaseContext());
        String username = prefs.getString("namePref", "");
        String domain = prefs.getString("domainPref", "");
        String password = prefs.getString("passPref", "");

        if (username.length() == 0 || domain.length() == 0 || password.length() == 0) 
            showDialog(UPDATE_SETTINGS_DIALOG);
            return;
        

        try 
            SipProfile.Builder builder = new SipProfile.Builder(username, domain);
            builder.setPassword(password);
            me = builder.build();

            Intent i = new Intent();
            i.setAction("android.SipDemo.INCOMING_CALL");
            PendingIntent pi = PendingIntent.getBroadcast(this, 0, i, Intent.FILL_IN_DATA);
            manager.open(me, pi, null);


            // This listener must be added AFTER manager.open is called,
            // Otherwise the methods aren't guaranteed to fire.

            manager.setRegistrationListener(me.getUriString(), new SipRegistrationListener() 
                    public void onRegistering(String localProfileUri) 
                        updateStatus("Registering with SIP Server...");
                    

                    public void onRegistrationDone(String localProfileUri, long expiryTime) 
                        updateStatus("Ready");
                    

                    public void onRegistrationFailed(String localProfileUri, int errorCode,
                            String errorMessage) 
                        updateStatus("Registration failed.  Please check settings. "+errorMessage);
                    
                );
         catch (ParseException pe) 
            updateStatus("Connection Error.");
         catch (SipException se) 
            updateStatus("Connection error.");
        
    

    /**
     * Closes out your local profile, freeing associated objects into memory
     * and unregistering your device from the server.
     */
    public void closeLocalProfile() 
        if (manager == null) 
            return;
        
        try 
            if (me != null) 
                manager.close(me.getUriString());
            
         catch (Exception ee) 
            Log.d("WalkieTalkieActivity/onDestroy", "Failed to close local profile.", ee);
        
    

    /**
     * Make an outgoing call.
     */
    public void initiateCall() 

        updateStatus(sipAddress);

        try 
            SipAudioCall.Listener listener = new SipAudioCall.Listener() 
                // Much of the client's interaction with the SIP Stack will
                // happen via listeners.  Even making an outgoing call, don't
                // forget to set up a listener to set things up once the call is established.
                @Override
                public void onCallEstablished(SipAudioCall call) 
                    call.startAudio();
                    call.setSpeakerMode(true);
                    call.toggleMute();
                    updateStatus(call);
                

                @Override
                public void onCallEnded(SipAudioCall call) 
                    updateStatus("Ready.");
                
            ;

            call = manager.makeAudioCall(me.getUriString(), sipAddress, listener, 30);

        
        catch (Exception e) 
            Log.i("WalkieTalkieActivity/InitiateCall", "Error when trying to close manager.", e);
            if (me != null) 
                try 
                    manager.close(me.getUriString());
                 catch (Exception ee) 
                    Log.i("WalkieTalkieActivity/InitiateCall",
                            "Error when trying to close manager.", ee);
                    ee.printStackTrace();
                
            
            if (call != null) 
                call.close();
            
        
    

    /**
     * Updates the status box at the top of the UI with a messege of your choice.
     * @param status The String to display in the status box.
     */
    public void updateStatus(final String status) 
        // Be a good citizen.  Make sure UI changes fire on the UI thread.
        this.runOnUiThread(new Runnable() 
            public void run() 
                TextView labelView = (TextView) findViewById(R.id.sipLabel);
                labelView.setText(status);
            
        );
    

    /**
     * Updates the status box with the SIP address of the current call.
     * @param call The current, active call.
     */
    public void updateStatus(SipAudioCall call) 
        String useName = call.getPeerProfile().getDisplayName();
        if(useName == null) 
          useName = call.getPeerProfile().getUserName();
        
        updateStatus(useName + "@" + call.getPeerProfile().getSipDomain());
    

    /**
     * Updates whether or not the user's voice is muted, depending on whether the button is pressed.
     * @param v The View where the touch event is being fired.
     * @param event The motion to act on.
     * @return boolean Returns false to indicate that the parent view should handle the touch event
     * as it normally would.
     */
    public boolean onTouch(View v, MotionEvent event) 
        if (call == null) 
            return false;
         else if (event.getAction() == MotionEvent.ACTION_DOWN && call != null && call.isMuted()) 
            call.toggleMute();
         else if (event.getAction() == MotionEvent.ACTION_UP && !call.isMuted()) 
            call.toggleMute();
        
        return false;
    

    public boolean onCreateOptionsMenu(Menu menu) 
        menu.add(0, CALL_ADDRESS, 0, "Call someone");
        menu.add(0, SET_AUTH_INFO, 0, "Edit your SIP Info.");
        menu.add(0, HANG_UP, 0, "End Current Call.");

        return true;
    

    public boolean onOptionsItemSelected(MenuItem item) 
        switch (item.getItemId()) 
            case CALL_ADDRESS:
                showDialog(CALL_ADDRESS);
                break;
            case SET_AUTH_INFO:
                updatePreferences();
                break;
            case HANG_UP:
                if(call != null) 
                    try 
                      call.endCall();
                     catch (SipException se) 
                        Log.d("WalkieTalkieActivity/onOptionsItemSelected",
                                "Error ending call.", se);
                    
                    call.close();
                
                break;
        
        return true;
    

    @Override
    protected Dialog onCreateDialog(int id) 
        switch (id) 
            case CALL_ADDRESS:

                LayoutInflater factory = LayoutInflater.from(this);
                final View textBoxView = factory.inflate(R.layout.call_address_dialog, null);
                return new AlertDialog.Builder(this)
                        .setTitle("Call Someone.")
                        .setView(textBoxView)
                        .setPositiveButton(
                                android.R.string.ok, new DialogInterface.OnClickListener() 
                                    public void onClick(DialogInterface dialog, int whichButton) 
                                        EditText textField = (EditText)
                                                (textBoxView.findViewById(R.id.calladdress_edit));
                                        sipAddress = textField.getText().toString();
                                        initiateCall();

                                    
                        )
                        .setNegativeButton(
                                android.R.string.cancel, new DialogInterface.OnClickListener() 
                                    public void onClick(DialogInterface dialog, int whichButton) 
                                        // Noop.
                                    
                        )
                        .create();

            case UPDATE_SETTINGS_DIALOG:
                return new AlertDialog.Builder(this)
                        .setMessage("Please update your SIP Account Settings.")
                        .setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() 
                            public void onClick(DialogInterface dialog, int whichButton) 
                                updatePreferences();
                            
                        )
                        .setNegativeButton(
                                android.R.string.cancel, new DialogInterface.OnClickListener() 
                                    public void onClick(DialogInterface dialog, int whichButton) 
                                        // Noop.
                                    
                        )
                        .create();
        
        return null;
    

    public void updatePreferences() 
        Intent settingsActivity = new Intent(getBaseContext(),
                SipSettings.class);
        startActivity(settingsActivity);
    

【问题讨论】:

【参考方案1】:

你的状态是什么? 在调试模式下启动应用程序并在 SipRegistrationListener 上获取 errorCode。

【讨论】:

对我来说它返回 -5 即注册超时。有什么想法吗?【参考方案2】:

我在使用 SipDemo,也遇到了注册失败的问题。在每次尝试注册期间,我收到 -5(TIME_OUT) 或 -9 (IN_PROGRESS) 或 -10(DATA_CONNECTION_LOST) 的错误代码。我从 sip2sip.info 获得了免费的 SIP 帐户,并添加了这一行:builder.setOutboundProxy("proxy.sipthor.net"); 解决了问题:

SipProfile.Builder builder = new SipProfile.Builder(username, domain);            
builder.setPassword(password);

builder.setOutboundProxy("proxy.sipthor.net");

me = builder.build();   

在三星 6.0.1 和 HTC 8.0.0 上测试。

【讨论】:

以上是关于VOIP SipDemo 注册失败(错误)的主要内容,如果未能解决你的问题,请参考以下文章

由于密码字段而导致注册失败错误?

安装程序失败,某些DLL的“注册失败”错误

SMACK API 带内注册失败并出现禁止错误

iOS 推送通知注册失败

Vue注册组件不断失败

Google 推送通知 - DOMException:注册失败 - 推送服务错误