私はアンドロイドコードでasmack XMPPを使用しています。 XMPPサーバーにログインしていますが、新しいユーザーを作成しようとしているときに問題が発生します。私が達成したいのは、次のとおりです。ユーザーを作成して、受け入れられないようにする(406)
- 管理者でログインしてください。
- 新しいユーザーを作成します。
- 管理者からログアウトします。
- 新規に割り当てられたユーザーとしてログインします。
- いくつかのアクションを実行します - ゲームをプレイします。
- 新しく作成されたユーザーを削除します。
これにより、登録が自動的に処理されるので、プレイヤーは登録しないようにすることができます。また、現在利用可能な名前を選ぶこともできます。
現在のコードは次のとおりです:
public void create_user(String username, String password) {
try {
connection.login("user", "pass");
} catch (XMPPException e) {
e.printStackTrace();
}
if (connection.isAuthenticated()) {
AccountManager manager = connection.getAccountManager();
try {
manager.createAccount(username, password);
} catch (XMPPException e) {
Log.w("[create_user] Cannot create new user: XMPP Exception.", "0");
e.printStackTrace();
} catch (IllegalStateException e) {
Log.w("[create_user] Cannot create new user: not logged in.", "0");
e.printStackTrace();
}
}
}
コードのログイン部分は成功です。コードの第2部分はそうではありません。私は次のエラーを受信しています:
W/[create_user] Cannot create new user: XMPP Exception.(1525): 0
W/System.err(1525): not-acceptable(406)
W/System.err(1525): at org.jivesoftware.smack.AccountManager.createAccount(AccountManager.java:246)
W/System.err(1525): at org.jivesoftware.smack.AccountManager.createAccount(AccountManager.java:207)
W/System.err(1525): at company.games.boxer.XMPPManager.create_user(XMPPManager.java:81)
W/System.err(1525): at company.games.boxer.XMPPManager.xmpp_login(XMPPManager.java:113)
W/System.err(1525): at company.games.boxer.XMPPClient.onCreate(XMPPClient.java:19)
W/System.err(1525): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
W/System.err(1525): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
W/System.err(1525): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
W/System.err(1525): at android.app.ActivityThread.access$2300(ActivityThread.java:125)
W/System.err(1525): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
W/System.err(1525): at android.os.Handler.dispatchMessage(Handler.java:99)
W/System.err(1525): at android.os.Looper.loop(Looper.java:123)
W/System.err(1525): at android.app.ActivityThread.main(ActivityThread.java:4627)
W/System.err(1525): at java.lang.reflect.Method.invokeNative(Native Method)
W/System.err(1525): at java.lang.reflect.Method.invoke(Method.java:521)
W/System.err(1525): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
W/System.err(1525): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
W/System.err(1525): at dalvik.system.NativeStart.main(Native Method)
誰かが理由を教えてもらえますか? user:pass(XMPPサーバーの管理者)としてログインしているので、ユーザーを作成するための十分な権限があります。
* ahem * ...ああ...あなたは 'apk'の*サーバー管理者のユーザー名とパスワードでこのコードを*発送するつもりはないのですか? – BRFennPocock
うれしいことですが、BRPocockによると、サーバにログインできるユーザ名/パスワードを送信するか、登録をサーバに移して、現在のユーザのログイン資格情報を返すようにしてくださいコードに管理者パスワードを入れる。 – Jave