1

Suse-Linux EC2 インスタンスに openfire サーバーをインストールしました。管理者に加えて「balaji」という名前のユーザーを 1 人作成して、openfire サーバーを構成しました。

次に、iOS プラットフォーム用の ilibjingle コードをインストールし、ビルドすることができました。シミュレーターで実行したところ、gmail-id で完全に機能しました。ログインし、名簿リストからユーザーを取得しました。

次に、openfire サーバーの IP アドレスを指すようにコードを変更し、ユーザー名に「balaji」(openfire で作成したもの) と適切なパスワードを指定しました。また、openfire サーバーに自己署名 SSL 証明書があります。このコードを実行すると、接続できましたが、ログインできませんでした (私は信じています)。ilibjingle コードは、Connect to Login to LoggedIn to Roster リストに移動することになっています。私のopenfireサーバーで実行したとき、ConnectからLoginに行きましたが、それ以上は何もありませんでした.

何がうまくいかなかったのでしょうか?これを機能させるには、openfire サーバーの何かを変更する必要がありますか? これが私のiPhoneコードです。

rootviewcontroller.mm には、次のスニペットがあります。

-(void) _mainGtalkThread:(id)sender
{
    NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
    //you need to setup name and passwd manuelly here
    char *name = "balaji";
    char *password = "mypasswd";
    [self gtalk_main:(char*)name userpassword:(char*)password];
    [pool release];
}


-(int) gtalk_main:(char*)un userpassword:(char*)password 
{
// This app has three threads. The main thread will run the XMPP client,
// which will print to the screen in its own thread. A second thread
// will get input from the console, parse it, and pass the appropriate
// message back to the XMPP client's thread. A third thread is used
// by MediaSessionClient as its worker thread.

buzz::Jid jid;
talk_base::InsecureCryptStringImpl pass;

std::string username = un;
if (username.find('@') == std::string::npos) {
    username.append("@localhost");
}
jid = buzz::Jid(username);
if (!jid.IsValid() || jid.node() == "") {
    printf("Invalid JID. JIDs should be in the form user@domain\n");
    return 1;
}
pass.password() = password;

buzz::XmppClientSettings xcs;

xcs.set_user(jid.node());
//xcs.set_resource("call");
xcs.set_host(jid.domain());
xcs.set_pass(talk_base::CryptString(pass));
xcs.set_use_tls(false);
xcs.set_allow_plain(true);

xcs.set_server(talk_base::SocketAddress("50.37.185.206", DEFAULT_PORT));
printf("Logging in as %s with user as %s\n", jid.Str().c_str(), jid.node().c_str());

talk_base::InitializeSSL();

talk_base::Thread athread;
talk_base::ThreadManager::SetCurrent(&athread);

talk_base::Thread* main_thread = talk_base::Thread::Current();
assert(main_thread!=NULL);

XmppPump pump;
//CallClient *client = new CallClient(pump.client());
gtalkClient_ = new gtalkClient(pump.client(), self);

pump.DoLogin(xcs, new XmppSocket(true), NULL);
main_thread->Run();

return 0;
}

別のファイル「gtalkclient.mm」には、次のものがあります。

gtalkClient::gtalkClient(buzz::XmppClient* xmpp_client, void * controller) :
xmpp_client_(xmpp_client), controller_(controller), media_engine_(NULL),
media_client_(NULL), call_(NULL), incoming_call_(false), auto_accept_(false),
pmuc_domain_("conference.localhost"), local_renderer_(NULL), remote_renderer_(NULL),
roster_(new RosterMap), portallocator_flags_(0)
{
    xmpp_client_->SignalStateChange.connect(this, &gtalkClient::OnStateChange);
}


void gtalkClient::OnStateChange(buzz::XmppEngine::State state) 
{         
    RootViewController * tvc = (RootViewController*)controller_;
    switch (state) {
      case buzz::XmppEngine::STATE_START:
        printf("connecting...");
      [tvc.roster_ removeAllObjects];
      [tvc.roster_ addObject:@"connecting..."];
      [tvc reloadTableViewData];
        break;

      case buzz::XmppEngine::STATE_OPENING:
        printf("logging in...");
      [tvc.roster_ removeAllObjects];
      [tvc.roster_ addObject:@"logging in..."];
      [tvc reloadTableViewData];
        break;

      case buzz::XmppEngine::STATE_OPEN:
        printf("logged in...");
      [tvc.roster_ removeAllObjects];
      [tvc.roster_ addObject:@"logged in..."];
      [tvc reloadTableViewData];
        InitPhone();
        InitPresence();
      // prepare to add roster
      [tvc.roster_ removeAllObjects];
        break;

      case buzz::XmppEngine::STATE_CLOSED:
        buzz::XmppEngine::Error error = xmpp_client_->GetError(NULL);
        printf("logged out...%s", strerror(error).c_str());
      [tvc.roster_ removeAllObjects];
      [tvc.roster_ addObject:@"logged out..."];
      [tvc reloadTableViewData];
    Quit();
      }
    }
4

1 に答える 1

4

libjingleサーバーでサンプル プログラムを実行しているときにも同じ問題が発生しました。openfireこれは、新しいバージョンのlibjingleが不明な機関の証明書をサポートしていなかったためです。

そのため、rev65で行われた変更を元に戻す必要がありますxmppsocket.cc(libjingleバージョン 0.5.6 に更新されたとき):
このリンクは、2 つのバージョンの違いを確認するのに役立ちます http://code.google.com/p/libjingle/source/diff ?spec=svn95&r=65&format=side&path=/trunk/talk/examples/login/xmppsocket.cc&old_path=/trunk/talk/examples/login/xmppsocket.cc&old=30

このコミットでは、不明な認証局の証明書を許可していた 2 行を削除しました。

上記の指示に従って問題を解決しました。または、以下のリンクをたどって完全なアイデアを得ることができます。 http://code.google.com/p/libjingle/issues/detail?id=250 .

于 2011-12-22T07:15:01.213 に答える