zoukankan      html  css  js  c++  java
  • Openfire S2S 监听与消息处理

    原文地址:http://yjl49.iteye.com/blog/1452570

    Openfire中Server to Server 连接默认使用5269 端口,在管理员后台的Server-->Server Settings --> Server to Server 页面有相应的配置项。

    首先看Service Enable 项:

    在用户选择了 Enabled 填写监听端口 提交后在jsp页面里调用的是ConnectionManager相应的方法:

    Java代码 
    1. ConnectionManager connectionManager = XMPPServer.getInstance().getConnectionManager();  
    2. connectionManager.enableServerListener(true);  
    3. connectionManager.setServerListenerPort(port);  

    在enableServerListener() 方法中主要调用以下两个方法:

    Java代码 
    1. createServerListener(String ip);  
    2. startServerListener();  

    相应的ip和端口信息被包装成一个SocketAcceptThread,做为一个独立的线程运行。在SocketAcceptThread 里面有一个BlockingAcceptingMode 成员,专门用来监听Socket连接。

    Java代码 
    1. public void run(){  
    2.     while(notTerminated){  
    3.        try{  
    4.            Socket sock = serverSocket.accept();  
    5.            if(sock !=null){  
    6.               Log.debug("Connect"+sock.toString());  
    7.               SocketReader reader =  
    8.                    connManager.createSocketReader(sock,false,serverPort,true);  
    9.               Thread thread = new Thread(reader,reader.getName());  
    10.               thread.setDaemon(true);  
    11.               thread.setPriority(Thread.NORM_PRIORITY);  
    12.               thread.start();  
    13.            }  
    14.        }  
    15.        catch(IOException ie){  
    16.           if(notTerminated){  
    17.              Log.error(......);  
    18.           }  
    19.        }  
    20.        catch(Throwable e){  
    21.           Log.error(......);  
    22.        }  
    23.     }  
    24. }  

    每监听到一个连接都会交由一个线程来接管。 这个线程运行SocketReader的run()方法,接收消息,具体的消息的接收和初步处理由SocketReader里面的SocketReadingMode对象进行。

    SocketReadingMode 反过来调用ServerSocketReader的createSession()方法根据namespace创建Session。

    所有其它域连接到本地服务器的session都由LocalIncomingServerSession保持,session的创建也是由它来进行。(目前Openfire只支持dailback的S2S验证方式,在Openfire3.7.0中 dialback是有问题的,在3.7.1中进行了fix。 ) sessio创建时会发送相应的握手信息给对方。

    初始建立的session是未验证的,此时如果对端发送iq、message、presence等消息由ServerSocketReader接收,其调用packetReceived() 方法验证域名并抛出PacketRejectedException,所以S2S开始发送的应该为验证信息。

    本地ServerSocketReader收到验证信息后由processUnknowPacket() 方法处理,调用LocalIncomingServerSession 的validateSubsequentDomain() 验证。

    具体的由一个ServerDialback对象进行处理(Openfire3.7.0的bug fix 中对这个类的代码进行了修改)。刚建立连接时发送了握手信息,这里的ServerDialback对象则验证对方返回的key是否正确,OK的情况下则发送成功通知。

    验证通过的session会加入到LocalIncomingServerSession的已鉴权列表中,后面发送的iq、message、presence消息就不会再被拦截。

  • 相关阅读:
    自定义ASP.NET MVC Html辅助方法
    逻辑回归代价函数的详细推导
    cv::Mat与IplImage 的相互转换
    [转]GDAL1.9.0版本编译后,打不开含中文路径文件的解决办法
    恢复matlab文件关联方法
    error LNK2001: unresolved external symbol "*******__cdecl****"
    如何Latex中把下标放置到正下方
    Office2010每次启动都要配置的解决办法
    TC中列出所有文件的快捷键:ctrl+b
    [转]STL中vector转数组(实际是数组的指针)
  • 原文地址:https://www.cnblogs.com/ilahsa/p/openfire.html
Copyright © 2011-2022 走看看