Delphi IdFTP[3] TIdFTP.Connect、IdFTP.ReadTimeout - 连接和超时的解读
Delphi IdFTP[3] TIdFTP.Connect、IdFTP.ReadTimeout - 连接和超时的解读
1、TIdFTP.Connect - 打开与FTP服务器的连接。
原型:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | procedure Connect(AAutoLogin: boolean = True ; const ATimeout: Integer = IdTimeoutDefault); reintroduce; procedure TIdFTP . Connect(AAutoLogin: boolean = True ; const ATimeout: Integer = IdTimeoutDefault); var TmpHost: String ; TmpPort: Integer ; begin try //APR 011216: proxy support TmpHost:=FHost; TmpPort:=FPort; try if (ProxySettings . ProxyType > fpcmNone) and (Length(ProxySettings . Host) > 0 ) then begin FHost := ProxySettings . Host; FPort := ProxySettings . Port; end ; inherited Connect(ATimeout); finally FHost := TmpHost; FPort := TmpPort; end ; //tryf GetResponse([ 220 ]); Greeting . Assign(LastCmdResult); if AAutoLogin then begin Login; DoAfterLogin; SendTransferType; // OpenVMS 7.1 replies with 200 instead of 215 - What does the RFC say about this? if SendCmd( 'SYST' , [ 200 , 215 , 500 ]) = 500 then begin {Do not translate} FSystemDesc := RSFTPUnknownHost; end else begin FSystemDesc := LastCmdResult . Text[ 0 ]; end ; DoStatus(ftpReady, [RSFTPStatusReady]); end ; except Disconnect; raise ; end ; end ; |
参数:
- AAutoLogin: boolean = True //连接时登录用户。默认值为True。
- Timeout: Integer = IdTimeoutDefault //IdTimeoutDefault是一个常量整数值(默认-1),指示在启动连接、读取或写入远程计算机系统的方法中应使用默认超时值。IdTimeoutDefault通常用作提供给 TIdTCPClient.Connect方法的超时参数的默认值。
描述:
- Connect是使用主机和端口属性打开到FTP服务器的连接的过程。当需要代理服务器连接时,Connect将尝试使用ProxySettings中主机和端口属性的值,但如果发生异常,Connect将恢复为原始主机和端口值。Connect调用继承的Connect方法来打开连接的物理套接字句柄。
- 当服务器的协议响应代码为220时,LastCmdResult中的值将分配给Greeting属性。
- 当AutoLogin为True时,Connect方法将使用Login方法对连接进行身份验证,并触发OnAfterLogin事件处理程序。Connect还发送新连接的TransferType,并发送FTP SYST命令以获取存储在SystemDesc中的主机FTP服务器。
- 成功完成上述步骤后,Connect使用ftpReady状态值触发OnStatus事件处理程序。如果在Connect中引发异常,则Connect调用Disconnect并重新引发应用程序异常处理程序的异常。
2、IdFTP.ReadTimeout - 指示等待可读连接的毫秒数。
- ReadTimeout是一个整数属性,指示连接应等待对等连接使用协议堆栈变得可读的毫秒数。
- ReadTimeout在ReadFromStack中使用。
- IdFTP.ReadTimeout 实际继承自 TIdTCPConnection.ReadTimeout
注意(个人经验和理解):
- 以上FTP连接的等待时间,如果只设置connect 的 Timeout 实际无效果,还要设置 ReadTimeout 的值
- Connect的Timeout 是相对于网络连接通畅的情况下,判断与服务器的连接所用的超时时间。
- ReadTimeout 是相对于客户端而言,读取的超时时间,即使网络不通畅的情况下照常判断。
- 如果不设置 ReadTimeout 则FTP的连接Connect 将会是 很长时间,大概30s左右(有时候更久)才会抛出异常,因为它本身的连接是阻塞式的。
创建时间:2021.09.15 更新时间:
博客园 滔Roy https://www.cnblogs.com/guorongtao 希望内容对你有所帮助,谢谢!
分类:
Delphi 控N-IdFTP
标签:
Delphi
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
2020-09-15 SQL 两表关联更新UPDATE (用一个表更新另一个表)
2020-09-15 SQL 条件语句 (IF, CASE WHEN, IFNULL)