2014-03-27 99 views
1

我决定从SOAP服务器移到DataSnap服务器& REST。我查看并遵循了几个教程,甚至尝试过DXE5演示,但我一直得到相同的结果。问题是我无法将客户端应用程序上的TSQLConnection连接到正在运行的DataSnap服务器。DataSnap服务器套接字错误10061

这里是代码:

Socket Error # 10061 
Connection refused.. 
OS = Windows 7 64bit 
RAD Studio XE5 Update 2 

继帕维尔Glowacki(和ohters)DataSnap多层视频教程。

在创建Datasnap客户端/服务器应用程序时,我无法将客户端TSQLConnection连接到DSServer。

  1. 服务器正在运行(localhost)!

  2. Firewal停用。

  3. 将端口211添加到Windows防火墙入站&出站规则。

  4. 我已经尝试创建DataSnat REST应用程序并发生相同的错误。

  5. 当在DXE和DXE3中执行此操作时,我会得到相同的结果。

步骤来重现

  1. 创建DataSnap服务器(尝试都DataModule的& DSServerModule)。
  2. 离开默认端口211(也尝试过其他几个端口(8080,9000)。
  3. 运行服务器。一切都OK了这里。
  4. 创建VCL窗体应用程序。
  5. 添加一个TSQLConnection对主要形式。
  6. 设置驾驶员的DataSnap。
  7. CommunicationProtocol = TCP/IP。
  8. DataSnapCOntext =的DataSnap/
  9. 主机名=本地主机(尝试127.0.0.1和我的电脑的IP地址)。
  10. LoginPropt = False。
  11. 运行服务器。
  12. 启动服务器。
  13. 在浏览器中打开工作正常。
  14. 将TSQLConnection上的Connected属性设置为true。
  15. 生成套接字错误10061,我无法过去。

这是堆栈跟踪。

[5110E67F]{IndySystem190.bpl} IdStack.TIdStack.RaiseSocketError (Line 771, "IdStack.pas" + 42) + $21 
[5110E606]{IndySystem190.bpl} IdStack.TIdStack.RaiseLastSocketError (Line 725, "IdStack.pas" + 1) + $F 
[5110E571]{IndySystem190.bpl} IdStack.TIdStack.CheckForSocketError (Line 699, "IdStack.pas" + 2) + $3 
[5110A9F4]{IndySystem190.bpl} IdStackWindows.TIdStackWindows.Connect (Line 1771, "IdStackWindows.pas" + 20) + $13 
[50DF5849]{IndyCore190.bpl} IdSocketHandle.TIdSocketHandle.Connect (Line 294, "IdSocketHandle.pas" + 1) + $25 
[50E01CF9]{IndyCore190.bpl} IdIOHandlerStack.TIdIOHandlerStack.ConnectClient (Line 344, "IdIOHandlerStack.pas" + 52) + $A 
[50E05283]{IndyCore190.bpl} IdIOHandlerSocket.TIdIOHandlerSocket.Open (Line 332, "IdIOHandlerSocket.pas" + 13) + $4 
[50E01011]{IndyCore190.bpl} IdTCPClient.TIdTCPClientCustom.Connect (Line 317, "IdTCPClient.pas" + 52) + $B 
[16F76AFD]{IndyIPClient190.bpl} IPPeerClient.TIdTCPClientPeerIP.Connect (Line 1166, "IPPeerClient.pas" + 0) + $5 
[520AC809]{DbxClientDriver190.bpl} Data.DbxSocketChannelNative.TDBXIdTCPLayer.Open (Line 378, "Data.DbxSocketChannelNative.pas" + 27) + $5 
[520AC44B]{DbxClientDriver190.bpl} Data.DbxSocketChannelNative.TDBXSocketChannel.Open (Line 149, "Data.DbxSocketChannelNative.pas" + 13) + $E 
[50059970]{rtl190.bpl } [email protected] (Line 4364, "System.pas" + 20) + $0 
[50060DA0]{rtl190.bpl } [email protected] (Line 23846, "System.pas" + 14) + $0 
[520AEA09]{DbxClientDriver190.bpl} Data.DBXTransportFilter.TDBXFilterSocketChannel.SetDBXProperties (Line 712, "Data.DBXTransportFilter.pas" + 8) + $10 
[520AE999]{DbxClientDriver190.bpl} Data.DBXTransportFilter.TDBXFilterSocketChannel.Open (Line 693, "Data.DBXTransportFilter.pas" + 0) + $5 
[520B0897]{DbxClientDriver190.bpl} Data.DBXClient.TDBXClientConnection.DerivedOpen (Line 430, "Data.DBXClient.pas" + 5) + $8 
[5214F8D7]{DbxCommonDriver190.bpl} Data.DBXCommon.TDBXConnection.Open (Line 8599, "Data.DBXCommon.pas" + 5) + $4 
[5214AC72]{DbxCommonDriver190.bpl} Data.DBXCommon.TDBXConnectionFactory.GetConnection (Line 6724, "Data.DBXCommon.pas" + 14) + $5 
[5214AB6D]{DbxCommonDriver190.bpl} Data.DBXCommon.TDBXConnectionFactory.GetConnection (Line 6701, "Data.DBXCommon.pas" + 0) + $5 
[51392D29]{dbexpress190.bpl} Data.SqlExpr.TSQLConnection.DoConnect (Line 2490, "Data.SqlExpr.pas" + 56) + $6 
[50A8AA4D]{dbrtl190.bpl} Data.DB.TCustomConnection.SetConnected (Line 3482, "Data.DB.pas" + 8) + $4 
[50128326]{rtl190.bpl } System.TypInfo.SetOrdProp (Line 2583, "System.TypInfo.pas" + 21) + $1 
[2110BA52]{designide190.bpl} DesignEditors.TPropertyEditor.SetOrdValue (Line 839, "DesignEditors.pas" + 2) + $E 
[211564F7]{designide190.bpl} VCLEditors.TBooleanProperty.MouseUp (Line 1864, "VCLEditors.pas" + 5) + $10 
[212A13CD]{vclide190.bpl} PropBox.TCustomPropListBox.ItemMouseUp (Line 1631, "PropBox.pas" + 17) + $1B 
[212A15C3]{vclide190.bpl} PropBox.TCustomPropListBox.MouseUp (Line 1696, "PropBox.pas" + 1) + $D 
[504634D8]{vcl190.bpl } Vcl.Controls.TControl.DoMouseUp (Line 7468, "Vcl.Controls.pas" + 2) + $28 
[50463554]{vcl190.bpl } Vcl.Controls.TControl.WMLButtonUp (Line 7481, "Vcl.Controls.pas" + 9) + $6 
[212A6D50]{vclide190.bpl} IDEInspListBox.TInspListBox.WMLButtonUp (Line 1632, "IDEInspListBox.pas" + 3) + $4 
[50462B49]{vcl190.bpl } Vcl.Controls.TControl.WndProc (Line 7224, "Vcl.Controls.pas" + 91) + $6 
[1ECD5CD1]{cxLibraryRS19.bpl} dxHooks.TdxSystemHook.ProcessHookProcs$qqriuii + $99 
[1ECD5A9A]{cxLibraryRS19.bpl} dxHooks.dxSystemGetMessageHook$qqsiuii + $16 
[50466E9F]{vcl190.bpl } Vcl.Controls.TWinControl.IsControlMouseMsg (Line 9807, "Vcl.Controls.pas" + 1) + $9 
[50467669]{vcl190.bpl } Vcl.Controls.TWinControl.WndProc (Line 10039, "Vcl.Controls.pas" + 153) + $6 
[5048AF69]{vcl190.bpl } Vcl.StdCtrls.TCustomListBox.WndProc (Line 7108, "Vcl.StdCtrls.pas" + 55) + $5 
[50466CAC]{vcl190.bpl } Vcl.Controls.TWinControl.MainWndProc (Line 9751, "Vcl.Controls.pas" + 3) + $6 
[501749C4]{rtl190.bpl } System.Classes.StdWndProc (Line 17010, "System.Classes.pas" + 5) + $0 
[5059214F]{vcl190.bpl } Vcl.Forms.TApplication.CancelHint (Line 11117, "Vcl.Forms.pas" + 6) + $E 
[50590DC3]{vcl190.bpl } Vcl.Forms.TApplication.ProcessMessage (Line 10288, "Vcl.Forms.pas" + 23) + $1 
[50590E06]{vcl190.bpl } Vcl.Forms.TApplication.HandleMessage (Line 10318, "Vcl.Forms.pas" + 1) + $4 
[50591141]{vcl190.bpl } Vcl.Forms.TApplication.Run (Line 10456, "Vcl.Forms.pas" + 26) + $3 

我该怎么做?

+0

当服务器开始运行时,您是否收到有关应用程序是应该被阻止还是被阻止的消息?如果不这样做,请检查数据模块是否正在自动创建 - 如果不是,请尝试移动它。 – RichardS

+0

为了澄清,它应该确保创建ServerContainer数据模块。 – RichardS

+0

美好的一天理查德,谢谢你的帖子。当我遇到这个问题时,我在上周的工作中测试了这个DataSnap功能。我们正处于几个项目的中间。所以很大的压力。当我周末回到家时,我决定玩一下,看看我能否解决这个问题。在短短几分钟后,围绕着测试应用程序的项目源,我注意到一些表单不在自动创建列表中,所以我将它们中的一些移到了自动创建和VOILA!这一切都很好。在这种情况下,您的解决方案是正确的,所以感谢您的意见 –

回答

2

确保ServerContainer数据模块在启动时自动创建,或自行创建。

-1

通过将TDSTCPServerTransport组件添加到我的ServerContainer数据模块来解决此问题。

+0

这并没有真正回答这个问题。如果您有不同的问题,可以通过单击[提问](http://stackoverflow.com/questions/ask)来提问。您还可以[添加赏金](http://stackoverflow.com/help/privileges/set-bounties)在您拥有足够的[声誉](http://stackoverflow.com/help/)时吸引更多人关注此问题什么声誉)。 – AgentConundrum

+0

我会让我的答案是这样,原因是同样的问题,我正在与RESTFULL + JSON应用程序,并添加DataSnap,但没有组件我有SocketError#10061 –

1

我得到套接字错误#10061与向导创建的DataSnap REST客户端模块在localhost

(测试端口8080的时候)我所做的是我跑了DataSnap REST服务器应用程序文件(.exe),并开始它在端口8080上的LocalHost上。我添加了一个新的DataSnap REST客户端模块。测试了8080端口和voilà!有效。