.net ftp下载文件报错:远程服务器返回错误(425)无法打开数据连接
csdh11 2025-01-20 12:03 26 浏览
问题描述
.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 命令连接和数据连接都是由客户端发起,这样就解决了服务端连接客户端时客户端防火墙拦截的问题。
相关推荐
- 探索Java项目中日志系统最佳实践:从入门到精通
-
探索Java项目中日志系统最佳实践:从入门到精通在现代软件开发中,日志系统如同一位默默无闻却至关重要的管家,它记录了程序运行中的各种事件,为我们排查问题、监控性能和优化系统提供了宝贵的依据。在Java...
- 用了这么多年的java日志框架,你真的弄懂了吗?
-
在项目开发过程中,有一个必不可少的环节就是记录日志,相信只要是个程序员都用过,可是咱们自问下,用了这么多年的日志框架,你确定自己真弄懂了日志框架的来龙去脉嘛?下面笔者就详细聊聊java中常用日志框架的...
- 物理老师教你学Java语言(中篇)(物理专业学编程)
-
第四章物质的基本结构——类与对象...
- 一文搞定!Spring Boot3 定时任务操作全攻略
-
各位互联网大厂的后端开发小伙伴们,在使用SpringBoot3开发项目时,你是否遇到过定时任务实现的难题呢?比如任务调度时间不准确,代码报错却找不到方向,是不是特别头疼?如今,随着互联网业务规模...
- 你还不懂java的日志系统吗 ?(java的日志类)
-
一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...
- 谈谈枚举的新用法--java(java枚举的作用与好处)
-
问题的由来前段时间改游戏buff功能,干了一件愚蠢的事情,那就是把枚举和运算集合在一起,然后运行一段时间后buff就出现各种问题,我当时懵逼了!事情是这样的,做过游戏的都知道,buff,需要分类型,且...
- 你还不懂java的日志系统吗(javaw 日志)
-
一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...
- Java 8之后的那些新特性(三):Java System Logger
-
去年12月份log4j日志框架的一个漏洞,给Java整个行业造成了非常大的影响。这个事情也顺带把log4j这个日志框架推到了争议的最前线。在Java领域,log4j可能相对比较流行。而在log4j之外...
- Java开发中的日志管理:让程序“开口说话”
-
Java开发中的日志管理:让程序“开口说话”日志是程序员的朋友,也是程序的“嘴巴”。它能让程序在运行过程中“开口说话”,告诉我们它的状态、行为以及遇到的问题。在Java开发中,良好的日志管理不仅能帮助...
- OS X 效率启动器 Alfred 详解与使用技巧
-
问:为什么要在Mac上使用效率启动器类应用?答:在非特殊专业用户的环境下,(每天)用户一般可以在系统中进行上百次操作,可以是点击,也可以是拖拽,但这些只是过程,而我们的真正目的是想获得结果,也就是...
- Java中 高级的异常处理(java中异常处理的两种方式)
-
介绍异常处理是软件开发的一个关键方面,尤其是在Java中,这种语言以其稳健性和平台独立性而闻名。正确的异常处理不仅可以防止应用程序崩溃,还有助于调试并向用户提供有意义的反馈。...
- 【性能调优】全方位教你定位慢SQL,方法介绍下!
-
1.使用数据库自带工具...
- 全面了解mysql锁机制(InnoDB)与问题排查
-
MySQL/InnoDB的加锁,一直是一个常见的话题。例如,数据库如果有高并发请求,如何保证数据完整性?产生死锁问题如何排查并解决?下面是不同锁等级的区别表级锁:开销小,加锁快;不会出现死锁;锁定粒度...
- 看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法
-
一、什么是死锁加锁(Locking)是数据库在并发访问时保证数据一致性和完整性的主要机制。任何事务都需要获得相应对象上的锁才能访问数据,读取数据的事务通常只需要获得读锁(共享锁),修改数据的事务需要获...
- 一周热门
- 最近发表
- 标签列表
-
- 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)
- 反恐24小时电话铃声 (33)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)