最近看一段老代码,两套程序,配置跟代码一模一样,放到两个服务器上,但是一个好一个坏,比较半天没看出原因,因为是老代码,异常捕获啥也没有,要来源码,加了异常处理,根据报错初步判定是配置问题,有问题的配置没读取到。
配置文件就几行字也一模一样看不出来,实在没办法拖到beyondCompare里,用文件比较,看到字节顺序标记标红了,怀疑是编码问题。然后16进制比较,果然,文字一样,但是有问题的文档开头多了几个字节,一看就觉得不妙,莫非是utf-8 BOM的问题?
试了下,果然,用非utf-8 BOM的就好了。
这老代码至少十年前的了,读取配置文件的代码调用的kernel32的
[DllImport("kernel32")]
static int GetPrivateProfileString(String ^section, String ^key, String ^def, StringBuilder ^retVal, int size,String ^filePath);
老代码没注释,有异常捕获但是没有记录日志,而且异常时还给添加了个默认值,现场的环境还是好久之前的了,真是吐血,代码里异常捕获了一定不要直接给吞了啊。