2013-07-05 64 views
0

我试图制作一个使用XMPP将消息发送到Gmail帐户的应用程序。我找到了一个提到谷歌XMPP服务器名称的链接,但我不认为我能够建立连接。使用smack的Android XMPP:服务器没有响应

编辑我改变了服务器的名称,我相信它能够建立连接。但它表示Rosters有0个条目。我正尝试使用Gmail帐户登录。新的异常我:

07-05 14:02:05.099: W/System.err(13903): java.security.KeyStoreException: java.security.NoSuchAlgorithmException: KeyStore jks implementation not found 
07-05 14:02:05.099: W/System.err(13903): at java.security.KeyStore.getInstance(KeyStore.java:119) 
07-05 14:02:05.099: W/System.err(13903): at org.jivesoftware.smack.ServerTrustManager.<init>(ServerTrustManager.java:70) 
07-05 14:02:05.099: W/System.err(13903): at org.jivesoftware.smack.XMPPConnection.proceedTLSReceived(XMPPConnection.java:824) 
07-05 14:02:05.099: W/System.err(13903): at org.jivesoftware.smack.PacketReader.parsePackets(PacketReader.java:267) 
07-05 14:02:05.099: W/System.err(13903): at org.jivesoftware.smack.PacketReader.access$000(PacketReader.java:43) 
07-05 14:02:05.099: W/System.err(13903): at org.jivesoftware.smack.PacketReader$1.run(PacketReader.java:70) 
07-05 14:02:05.099: W/System.err(13903): Caused by: java.security.NoSuchAlgorithmException: KeyStore jks implementation not found 
07-05 14:02:05.099: W/System.err(13903): at org.apache.harmony.security.fortress.Engine.notFound(Engine.java:177) 
07-05 14:02:05.099: W/System.err(13903): at org.apache.harmony.security.fortress.Engine.getInstance(Engine.java:151) 
07-05 14:02:05.099: W/System.err(13903): at java.security.KeyStore.getInstance(KeyStore.java:116) 
07-05 14:02:05.099: W/System.err(13903): ... 5 more 

原来这里是例外:

07-05 13:30:23.444: W/System.err(12434): at org.jivesoftware.smack.PacketReader.parsePackets(PacketReader.java:306) 
07-05 13:30:23.454: W/System.err(12434): at org.jivesoftware.smack.PacketReader.access$000(PacketReader.java:44) 
07-05 13:30:23.454: W/System.err(12434): at org.jivesoftware.smack.PacketReader$1.run(PacketReader.java:76) 
07-05 13:30:38.229: D/Smack(12434): Start Login 
07-05 13:30:43.235: E/Smack(12434): Error: No response from the server. 
07-05 13:30:43.235: W/System.err(12434): No response from the server.: 
07-05 13:30:43.235: W/System.err(12434): at org.jivesoftware.smack.NonSASLAuthentication.authenticate(NonSASLAuthentication.java:58) 
07-05 13:30:43.235: W/System.err(12434): at org.jivesoftware.smack.SASLAuthentication.authenticate(SASLAuthentication.java:232) 
07-05 13:30:43.245: W/System.err(12434): at org.jivesoftware.smack.XMPPConnection.login(XMPPConnection.java:341) 
07-05 13:30:43.245: W/System.err(12434): at org.jivesoftware.smack.XMPPConnection.login(XMPPConnection.java:301) 
07-05 13:30:43.255: W/System.err(12434): at org.jivesoftware.smack.XMPPConnection.login(XMPPConnection.java:283) 
07-05 13:30:43.255: W/System.err(12434): at com.example.xmpp.MessageTask.doInBackground(MessageTask.java:33) 
07-05 13:30:43.255: W/System.err(12434): at com.example.xmpp.MessageTask.doInBackground(MessageTask.java:1) 
07-05 13:30:43.265: W/System.err(12434): at android.os.AsyncTask$2.call(AsyncTask.java:287) 
07-05 13:30:43.265: W/System.err(12434): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305) 
07-05 13:30:43.275: W/System.err(12434): at java.util.concurrent.FutureTask.run(FutureTask.java:137) 
07-05 13:30:43.275: W/System.err(12434): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230) 
07-05 13:30:43.275: W/System.err(12434): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076) 
07-05 13:30:43.285: W/System.err(12434): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569) 
07-05 13:30:43.285: W/System.err(12434): at java.lang.Thread.run(Thread.java:856) 

这里是我的代码:

ConnectionConfiguration config = new ConnectionConfiguration("xmpp.l.google.com", 5222); 
     XMPPConnection connection = new XMPPConnection(config); 
     try { 
      Log.d("Smack", "Start Connect"); 
      connection.connect(); 
      Log.d("Smack", "Start Login"); 
      connection.login(user, pwd); 
      Roster roster = connection.getRoster(); 
      //Get all rosters 
      Collection<RosterEntry> entries = roster.getEntries(); 
      //loop through 
      Log.d("Smack", "Start Rosters"); 
      for (RosterEntry entry : entries) { 
      //example: get presence, type, mode, status 
      Presence entryPresence = roster.getPresence(entry.getUser()); 
       String status = entryPresence.getStatus(); 
       Toast.makeText(context, status, Toast.LENGTH_LONG).show(); 
       Log.d("Smack", "Print rosters"); 
      } 
      Log.d("Smack", "End Rosters"); 

     } catch (XMPPException e) { 
      // TODO Auto-generated catch block 
      Log.e("Smack", "Error: " + e.getMessage()); 
      e.printStackTrace(); 
     } 
+0

你有没有试着用比谷歌的其他XMPP服务器上测试它?谷歌正在开始从XMPP切换到环聊应用的新协议。 **请尝试xmpp.l.google.com,并告诉我它是否有效** – Vannen

+0

我尝试过使用该服务器,并且收到了上面发布的异常。我只是使用错误的谷歌服务器?我目前正在尝试使用Google帐户登录。 – AndroidDev93

+0

有一个名为Beem的项目,它也使用asmack进行XMPP连接,并且它是开源的。你可以尝试一下,看看它是否仍然适用于Google Talk。 ** http://beem-project.com/projects/beem/files ** – Vannen

回答

2
+0

真棒,第一个链接解决了我的问题。 – AndroidDev93

+0

@Vannen我遵循这种方式,它显示信任存储路径中的错误,在java.io.File的java.io.File.fixSlashes(File.java:185) 处抛出NPE java.lang.NullPointerException 。 (File.java:134) at java.io.FileInputStream。 (FileInputStream.java:105) at org.jivesoftware.smack.ServerTrustManager。 (XTPConnection.java:839) –