百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

.net ftp下载文件报错:远程服务器返回错误(425)无法打开数据连接

csdh11 2025-01-20 12:03 30 浏览

问题描述

.net 使用 ftp 下载文件,在测试环境正常,部署到生产环境就报错【System.Net.WebException: 远程服务器返回错误: (425) 无法打开数据连接】。

运维组说 ftp 服务器是用 SuSE 搭的vsftp。

问题原因探索

无法打开数据连接,说明客户端和服务器端在建立数据连接的时候失败了。而数据连接的建立方式有两种:主动模式和被动模式。

1、主动模式和被动模式区别

ftp 主动模式和被动模式是两种不同的数据连接模式,用于在 ftp 客户端和服务器之间进行数据传输。它们的主要区别在于数据连接的建立方式。默认就是主动模式.

(1)在 ftp 主动模式(PORT)下,连接过程如下:

  • 1、客户端随机开启一个端口N(大于1023)向服务器的21号端口发起连接(包含发送用户名和密码)。
  • 2、客户端开放N+1号端口进行监听,并向服务器发出 PORT N+1 命令,告诉服务端客户端采用主动模式并开放了端口。
  • 3、服务器在收到 PORT 命令后,会选择本地 ftp 数据端口(通常为20)来连接客户端指定的端口N+1。

因为 ftp 服务器主动连接到了 ftp 客户端,因此称为主动模式。

(2)被动模式(PASV)连接过程如下:

  • 1、同主动模式第1步
  • 2、客户端开放N+1号端口进行监听,向服务器发送PASV命令,通知服务器自己处于被动模式。
  • 3、服务器收到命令后,会开放一个大于1023的端口P进行监听,然后用PORT P命令通知客户端,自己的数据端口是P。
  • 4、客户端收到命令后,会通过N+1号端口连接服务器的端口P,然后在两个端口之间进行数据传输。

借用网络上的图:

因为 ftp 客户端主动连接到了 ftp 服务器,因此称为被动模式。

二者区别:

2、先确定是不是被动模式配置问题

ftp 客户端在连接 ftp 服务器时,可以使用主动模式或被动模式。被动模式通常更适用于服务器在防火墙后面的情况。先确保在部署到生产环境时正确配置了被动模式。

确定方法:选择一个能连接生产服务器环境的的服务器,使用客户端【FileZilla】,在传输设置中的传输模式中不管是设置主动还是被动,都能建立连接,说明建立的连接和ftp服务器没有关系,那只有和客户端连接有关。

3、确认客户端 .net 程序正确配置了被动模式的相关参数

查看连接 ftp 的代码:

private static FtpWebRequest ConnectWithConfigId(int configId,String path)
{  
    var ftpInfoWithConfig = GetFtpInfoWithConfigId(configId);

    // 根据uri创建FtpWebRequest对象
    FtpWebRequest reqFTP = (FtpWebRequest)FtpWebRequest.Create(new Uri(ftpInfoWithConfig.FtpAddress + path));
    // 指定数据传输类型
    reqFTP.UseBinary = true;
    //指定数据传输模式
    if (usePassive == "1")
        reqFTP.UsePassive = true;
    else
        reqFTP.UsePassive = false;
    // ftp用户名和密码
    SecureString sPassword = new SecureString();
    foreach (var p in ftpInfoWithConfig.FtpPassword)
    {
        sPassword.AppendChar(p);
    }
    reqFTP.Credentials = new NetworkCredential(ftpInfoWithConfig.FtpUserName, sPassword);
    return reqFTP;
}

ftp 地址和密码都没有问题,那说明是传输模式的问题,模式由参数 UsePassive 设置:

//
// 摘要:
//     获取或设置客户端应用程序的数据传输过程的行为。
//
// 返回结果:
//     如果客户端应用程序的数据传输过程侦听数据端口上的连接,则为 false;如果客户端应在数据端口上启动连接,则为 true。默认值为 true。
//
// 异常:
//   T:System.InvalidOperationException:
//     对于一个已在进行的请求为此属性指定了一个新值。
public bool UsePassive { get; set; }

现在使用的 UsePassive 为 false,说明它使用的是主动模式而不是被动模式。

4、问题确认

通过上面的描述,可以知道由于客户端并没有主动和服务端建立数据端口的连接,而是由服务器来连接客户端指定的端口,那么客户端的防火墙就有可能拦截阻止连接(被防火墙视为不安全或恶意行为),这次的问题应该就属于这个情况。

被动模式相对来说更加灵活,因为客户端主动连接到服务器指定的端口。

在生产环境,客户端应用程序的数据传输过程侦听数据端口上的连接会失败,那应该是让客户端在数据端口上启动连接。

问题解决

将 UsePassive 设为 true,即使用被动模式后与 ftp 建立连接成功,最终上传成功。

设置成了被动模式,ftp 命令连接和数据连接都是由客户端发起,这样就解决了服务端连接客户端时客户端防火墙拦截的问题。

相关推荐

知名软件变“木马”:2小时感染10万电脑

近日,腾讯电脑管家监测发现,一款通过“驱动人生”升级通道,并同时利用“永恒之蓝”高危漏洞传播的木马突然爆发,仅2个小时受攻击用户就高达10万。腾讯电脑管家可精准拦截该病毒攻击,管家团队也将持续跟踪该款...

腾讯电脑管家发布病毒预警:“驱动人生木马”爆发,2小时感染10万台电脑

新华网天津12月15日电(记者周润健)腾讯电脑管家15日紧急发布病毒预警,14日下午,腾讯电脑管家监测发现,一款通过“驱动人生”升级通道,并同时利用“永恒之蓝”高危漏洞传播的木马突然爆发,仅2个小时受...

全新“撒旦”勒索病毒来袭 瑞星推出独家解密工具

新华社北京7月26日电瑞星威胁情报平台近日发现多起国内用户感染“撒旦”勒索病毒事件。据瑞星安全研究人员介绍,该病毒运行后会加密受害者计算机文件,加密完成后会用中英韩三国语言索取1个比特币作为赎金,并...

新勒索病毒“WannaCry”疯狂来袭 乌克兰副总理电脑中招

据外媒报道,从6月27日开始,一种新勒索病毒再次疯狂来袭,已席卷欧洲多个国家,连乌克兰副总理的电脑都已中招。报道称,这轮病毒足以与五月席卷全球的勒索病毒“WannaCry”的攻击性相提并论。该病毒代号...

蠕虫病毒利用“永恒之蓝”漏洞传播 单位局域网受威胁最大

日前,火绒安全团队通过“火绒威胁情报系统”发现蠕虫病毒“Worm/Sharp”正在全网传播,其中在政府、企业、学校、医院等单位的局域网具有非常强的传播能力。该病毒通过“永恒之蓝”漏洞、多个电脑常用端口...

新病毒爆发:利用“永恒之蓝”传播,2小时感染10万台电脑挖矿

驱动人生发布的声明。据腾讯安全专家介绍,通过追溯病毒传播链发现,该病毒自12月14日约14点,利用“驱动人生”、“人生日历”等软件最早开始传播,另有约30%的传播通过“永恒之蓝”漏洞在局域网内进行主动...

逍遥安卓模拟器定制手游电脑版 手机电脑账号完全互通

从今年起大量回合制端游转向手游方向,无论是《梦幻西游》、《大话西游》、《神武》还是刚刚发行的《问道》手游,都是非常重度需要大量时间来做任务挂机升级的游戏。很多人习惯了端游的时候一个电脑可以多开的玩法,...

安卓模拟器绿色U盘移动版 公司玩游戏无痕迹

安卓模拟器已经不稀奇了!随着安卓手游的盛行,特别是《梦幻西游手游》之类的重度手游发布,玩手游花的时间也越来越多。用手机玩这些游戏存在着屏幕小、点量少、费流量还有容易被电话打断,在电脑上用安卓模拟器玩游...

苹果推出 iCloud 照片和视频转移服务:可转移至谷歌相册

IT之家3月4日消息据MacRumors今日报道,苹果公司本周推出了一项新服务,帮助iCloud用户方便快捷的将其存储的照片和视频转移到谷歌照片上。苹果在其支持文档中表示,用户可以登...

NAS PK台,4核带m.2的威联通TS-264C vs 双核TS-462C

因为618年中大促看到威联通TS-264C和TS-462C这两机型售价差不多,就做个比较以供参考。毕竟作为自2007年以来就一直卖威联通的NAS老油来说,对威联通各NAS机型的识别还是相当全面的,对不...

前端学AI(七):构造 RAG 系统评估测试数据集

引言在基于DeepSeek+Chroma+LangChain开发一个简单RAG系统...

惨重教训!调查显示挪威“英斯塔”号宙斯盾舰撞油轮后本不必“丧命”

最新公布的调查报告显示,挪威皇家海军“英斯塔”号护卫舰2018年11月与油轮相撞后,如果其舰员接受了更好的损管训练,并且对舰艇的稳定特性更加熟悉的话,这艘宙斯盾型战舰本来是可以挽救的。↑挪威“英斯塔”...

「必买」盘点2021年男人们的败家清单,越“败”越香

心里总想买点啥?看看《必买》,全网最有料的场景种草指南。草原割不尽,春风吹又生。在过去的2021年,不断被各种数码产品种草,一直在买买买,剁手不停。大部分产品都经过详细的对比做足了功课,也有部分是一时...

实现浏览器播放rtsp视频流的解决方案

有同学问道:需要实时播放摄像头rtsp视频流,而浏览器不能直接播放,怎样解决?实现这个需求可以通过插件或者转码来实现。要实现这个目的,可以采用的方案非常得多,有商业的也有开源的,这里主要列举一些开源的...

ISO9000你知道多少?

1ISO9000族标准是什么?ISO9000族标准是指由国际标准化质量管理和质量保证技术委员会(ISO/TC176)制订的所有国际标准。ISO9000族标准可帮助各种类型和规模的组织实施并有效运行质...