2

vysper xmpp サーバーを作成しています。これが私のコードです:

public static void main(String[] args) throws Exception {

    XMPPServer server = new XMPPServer("myserver.org");

    StorageProviderRegistry providerRegistry = new MemoryStorageProviderRegistry();

    AccountManagement accountManagement = (AccountManagement) providerRegistry.retrieve(AccountManagement.class);

    Entity user = EntityImpl.parseUnchecked("user@myserver.org");
    accountManagement.addUser(user, "password");

    server.setStorageProviderRegistry(providerRegistry);

    server.addEndpoint(new TCPEndpoint())

    server.setTLSCertificateInfo(new File("keystore.jks"), "boguspw");

    //server.setTLSCertificateInfo(new File("bogus_mina_tls.cert"), "boguspw");

    server.start();
    System.out.println("Vysper server is running...");

    server.addModule(new EntityTimeModule());
    server.addModule(new VcardTempModule());
    server.addModule(new XmppPingModule());
    server.addModule(new PrivateDataModule());
}

両方の証明書ファイルを試しました。(keystore.jks,bogus_mina_tls.cert)

サーバーを起動した後、サーバーに接続し、ログインを試みますが、ログインできません。

SmackConfiguration.setPacketReplyTimeout(5000);

    config = new ConnectionConfiguration("myserver.org", port, "localhost");
    config.setSelfSignedCertificateEnabled(true);
    config.setSecurityMode(ConnectionConfiguration.SecurityMode.enabled);
    config.setSASLAuthenticationEnabled(true);

// config.setKeystorePath("keystore.jks");

// config.setTruststorePath("keystore.jks");

    config.setKeystorePath("bogus_mina_tls.cert");
    config.setTruststorePath("bogus_mina_tls.cert");

    config.setTruststorePassword("boguspw");

    XMPPConnection.DEBUG_ENABLED = true;
    connection = new XMPPConnection(config);

    try {
        connection.connect();

    } catch (XMPPException e) {
        System.out.println("Error connect");
        e.printStackTrace();
    }

    System.out.println("Connected: " + connection.isConnected());

    try {
        System.out.println(connection.isAuthenticated());
        connection.login("user", "password");

    } catch (XMPPException e) {
        System.out.println("Error login");
        e.printStackTrace();
    }

私はこの例外をキャッチします:

SASL 認証 PLAIN が失敗しました: 不正なエンコード: org.jivesoftware.smack.SASLAuthentication.authenticate(SASLAuthentication.java:337) で org.jivesoftware.smack.XMPPConnection.login(XMPPConnection.java:203) で org.jivesoftware.smack. Connection.login(Connection.java:348) at com.protocol7.vysper.intro.WorkingClient.init(WorkingClient.java:57) at com.protocol7.vysper.intro.WorkingClient.(WorkingClient.java:27) at com. protocol7.vysper.intro.Runclient.main(Runclient.java:11)

これらの例 ( 1st2nd )を見てきましたが、機能しません。

4

1 に答える 1

2

最初に、サーバー証明書はユーザー認証には使用されず、クライアントとサーバー間の安全な通信チャネルを提供するために使用されることに注意してください。

ログから、ユーザーとパスワードを使用して、認証方法が「SASLPLAIN」であることがわかります。

サーバーでは、ユーザー名/パスワードを次のように設定しています。

accountManagement.addUser("user@myserver.org", "password");

しかし、あなたが使用しているクライアントでは

connection.login("user", "password");

これはあなたが投稿しているエラーメッセージとは一致しませんが、正しいユーザー/パスワードで再試行することをお勧めします。

于 2012-08-19T10:25:00.750 に答える