.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族标准可帮助各种类型和规模的组织实施并有效运行质...
- 一周热门
- 最近发表
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)
- dos 删除目录下所有子目录及文件 (36)