2020年12月,我们公司为客户方开发了一套以C#开发的客户端,在使用市场内部的dfs图片存储服务器的时候,提示了 “指定了无效的IP地址” 如图
分析:提示后 感觉甚是奇怪,在我司访问上传皆正常(我司内部DFS服务IP: 192.168.100.100),遂专心钻研,查明问题。然不负众望,终得查询原因,请看下面的错误提示代码
上传FastDFS文件异常,异常信息:指定了无效的 IP 地址。异常位置: 在 System.Net.IPAddress.InternalParse(String ipString, Boolean tryParse)
在 System.Net.IPAddress.Parse(String ipString)
在 FastDFS.Client.FastDFSClient.GetStorageNode(String groupName) 位置 f:\开源项目\FastDFS.Client\FastDFS.Client\FastDFSClient.cs:行号 26
在 RTAgri.Tools.FastDFSHelper.Upload(String filePath)
提示了FastDFSClient内部在处理IP时,由于网段问题解析失败,提示“指定了无效的IP”
问题:客户方的服务器地址为 10.10.20.122. 而客户方的网络是A类,但是他们的网络使用却是转为C类地址来使用的,这就是在FastDFSClient内部,进行IP解析的时候,默认是使用A类地址来解析的,但是传的却是C类的地址IP,导致解析失败,提示了无效的IP等错误,我查询了FastDFSClient C# 源码,如下图
错误代码在 IPAddress.Parse方面。
解决版本:暂时还没有解决版本,由于当前客户是这种A转C的网络模式,所以暂时使用的是OSS上传的,如果说彻底的解决方法的话,就是重写FastDFS源码,修改解析方法,重新生成DLL文件,这个我还在研究,大家可以持续关注我的博客,一旦解决我会及时放上来,另附DFS的源码开发地址 :https://github.com/smartbooks/FastDFS.Client
------------20210121 日志
已经找到解决方法,修改fastdfs源码,重写GetStorageNode方法,新增一个string ip参数,替换trackerResponse.IpStr方法,源码修改后将生成的dll文件重新引用,调用时传入IP即可。