症状(SYMPTOM):
服务端tvnserver-2.0.4,客户端tvnviewer-1.5.4,采用vs2010编译,操作系统为WinXP SP2/SP3。客户端在连接并且通过验证后报Connection Closed。该问题与验证方式、服务端屏幕分辨率等无关。该症状不是必然发生在每台机器上,经测试,部分环境下不会出现,但没有得到精确地规律。
原因(CAUSE):
经查,该症状是由于服务器在验证客户端后为客户端创建桌面对象时,返回NULL,服务器主动断开了客户端的连接所致,见RfbClient.cpp文件的RfbClient::execute函数,代码如下:
void RfbClient::execute(){
...
m_desktop = m_extAuthListener->onClientAuth(this);
...
}
RfbClient是RFB协议的客户端类,服务器为每个RFB客户端创建一个RfbClient对象,每个对象有一个工作线程,RfbClient::execute是工作线程方法。m_desktop返回NULL,导致抛出异常,服务器主动关闭连接。继续跟踪,调用路径(调用栈)如下:
Thread::threadProc()
RfbClient::execute()---(rfb-sconn工程的RfbClient.cpp)
RfbClientManager::onClientAuth()---(RfbClientManager.cpp)
WinDesktop::WinDesktop()---(WinDesktop.cpp)