smack 源码分析一(android上实现长连接)

http://blog.csdn.net/wqhjfree/article/details/7194383

前段时间应一个项目需求: 要求给终端短信, 联系人信息做一个云存储云备份及云端远程控制终端并且云端能够推送消息到终端的需求. 这需要在终端与云端建立一个长连接以便云端消息能及时推送到终端. 所以项目中用到了smack框架.  smack功能强大, 远不止本文所写的这点内容. 现在我只将对smack的理解以及项目中对smack的使用心得总结并记录下来, 一则给大家分享 , 二则也算是一个技术经验的累积. 但基于我混乱的表达能力和可能的理解上的偏差可能会有些错误. 欢迎各位大虾大牛拍砖. 

项目中用到smack的长连接这块关键有以下这几个类: Connection , XMPPConnection , PakcetWriter , PacketReader. 如下图: 

smack 源码分析一(android上实现长连接)_第1张图片

查看XMPPConnection源码:

[java]  view plain copy
  1. protected void connectUsingConfiguration(ConnectionConfiguration config) throws XMPPException {  
  2.         String host = config.getHost();  
  3.         int port = config.getPort();  
  4.         try {  
  5.   
  6.             if (this.socket == null || this.socket.isClosed()) {  
  7.   
  8.                 LogUtil.i(TAG, "this.socket == null || this.socket.isClosed()");  
  9.                 if (config.getSocketFactory() == null) {  
  10.                     this.socket = new Socket(host, port);  
  11.                 } else {  
  12.                     this.socket = config.getSocketFactory().createSocket(host, port);  
  13.                 }  
  14.             }  



 
 可以看到, connectUsingConfiguration(ConnectionConfiguration config) 是长连接入口, 传递config制定服务器ipAddress和port , 然后根据config创建一个socket对象. 紧接着调用initConnection()方法, 而在initConnection()中:  
  
 

[java]  view plain copy
  1. private void initConnection() throws XMPPException {  
  2.   
  3.             usingCompression = false;  
  4.   
  5.         // Set the reader and writer instance variables  
  6.         initReaderAndWriter();  
  7.   
  8.         try {   
  9. //            if (isFirstInitialization) {  
  10.                 packetWriter = new PacketWriter(this);  
  11.                 packetReader = new PacketReader(this);  
  12.   
  13.                 // If debugging is enabled, we should start the thread that will  
  14.                 // listen for  
  15.                 // all packets and then log them.  
  16.                 if (config.isDebuggerEnabled()) {  
  17.                     addPacketListener(debugger.getReaderListener(), null);  
  18.                     if (debugger.getWriterListener() != null) {  
  19.                         addPacketSendingListener(debugger.getWriterListener(), null);  
  20.                     }  
  21.                 }  
  22. //            } else {  
  23. //                packetWriter.init();  
  24. //                packetReader.init();  
  25. //            }  
  26.   
  27.             // Start the packet writer. This will open a XMPP stream to the  
  28.             // server  
  29.             packetWriter.startup();  
  30.             // Start the packet reader. The startup() method will block until we  
  31.             // get an opening stream packet back from server.  
  32.             packetReader.startup();  
  33.   
  34.             // Make note of the fact that we're now connected.  
  35.             connected = true;  

以上执行顺序是

1. initReaderAndWriter()方法通过上面创建的socket实例化connection

的Writer和Reader.


2. 实例化PacketWriter和PacketReader对象.

PacketWriter就是向服务器发送数据发送心跳包一直保持与服务器的连接连. PacketReader则是不断的读取并且解析服务器推送的消息.


3. 分别调用packetWriterpacketReader的startup()方法.

至此整个连接过程就建立完成了.



   长连接大致流程基本就这样, 也许还是一头雾水.  

1.终端如何发生心跳包与服务器一直保持联系的呢.

2.服务器推送消息到终端, 终端是如何根据消息进行分发处理的呢. 

 

请看: smack 源码分析- PacketReader (android上实现长连接) 和

smack 源码分析- PacketWriter (android上实现长连接) 两篇文章. 


你可能感兴趣的:(smack 源码分析一(android上实现长连接))