SIP API に問題があります。私は d.android.com のガイドに従っており、アプリケーションをテストするために sip2sip.info から無料の SIP アカウントを取得しました。更新:私は ekiga.net を試し、Kamailio サーバーも自分でセットアップしましたが、それらも役に立ちませんでした。
プロファイルを登録しようとすると、エラー メッセージ「0」で失敗します。コードは次のとおりです。
package com.mysys.mysip;
import java.text.ParseException;
import android.net.sip.SipException;
import android.net.sip.SipManager;
import android.net.sip.SipProfile;
import android.net.sip.SipRegistrationListener;
import android.os.Bundle;
import android.app.Activity;
import android.app.PendingIntent;
import android.content.Intent;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
public class MainActivity extends Activity {
public SipManager mSipManager = null;
public SipProfile mSipProfile = null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (mSipManager == null) {
mSipManager = SipManager.newInstance(this);
}
Button connectButton = (Button) findViewById(R.id.buttonConnect);
connectButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
buildProfile();
if (mSipProfile != null) {
openProfile();
}
}
});
}
public void buildProfile() {
try {
SipProfile.Builder builder = new SipProfile.Builder("censored", "sip2sip.info");
builder.setPassword("censored");
mSipProfile = builder.build();
} catch (ParseException e) {
Log.e("SipProfile.Builder", "Parse error!");
e.printStackTrace();
}
}
public void openProfile() {
Intent intent = new Intent();
intent.setAction("com.mysys.sip.INCOMING_CALL");
PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, Intent.FILL_IN_DATA);
SipRegistrationListener listener = new SipRegistrationListener() {
@Override
public void onRegistering(String localProfileUri) {
Log.i("SIP Registration", "Registering.");
updateStatus("Registering...");
}
@Override
public void onRegistrationDone(String localProfileUri, long expiryTime) {
Log.i("SIP Registration", "Done!");
updateStatus("Registered! Yay!");
}
@Override
public void onRegistrationFailed(String localProfileUri, int errorCode, String errorMessage) {
Log.e("SIP Registration", "Failed! URI: " + localProfileUri + " Reason: " + errorMessage);
updateStatus("Registration failed.");
}
};
try {
mSipManager.open(mSipProfile, pendingIntent, null);
mSipManager.setRegistrationListener(mSipProfile.getUriString(), listener);
} catch (SipException e) {
e.printStackTrace();
}
}
public void updateStatus(final String status) {
this.runOnUiThread(new Runnable() {
public void run() {
TextView statusView = (TextView) findViewById(R.id.textViewStatus);
statusView.setText(status);
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menu_settings:
Intent intent = new Intent(this, SettingsActivity.class);
startActivity(intent);
}
return super.onOptionsItemSelected(item);
}
}
Android SDK 自身のデモと比較して、コードを 2 回見直しましたが、何も見つかりませんでした。質問する前にも検索しましたが、関連する唯一のことはプロトコルを TCP に設定することでしたが、問題は解決しませんでした。