我有一个C#控制台应用程序,可以在运行时创建,解析和删除多个xml文件。该应用程序曾经在.Net 2.0的Windows 2003服务器上正常运行。 最近,应用程序框架升级到> net 4.0,Windows Server OS升级到Windows 2008 64位。
从那时起,应用程序随机遇到以下异常:
Access to the path 'D:\Content\iSDC\GDCOasis\GATE_DATA\LOG\635125008068192773\635125008074911566\SOD\AllRespId.xml' is denied.
at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
at System.IO.File.Delete(String path)
at ProcessGateFile.SOD.saveFile(String psFile, String psXMLString, Boolean isNonAscii)
创建,解析和删除的代码如下:
saveFile(tmpPath + "\\SOD\\AllRespId.xml", "<?xml version= \"1.0\" ?><XML>" + sbldDistinctResp.ToString() + "</XML>", isChinese);
//Save list of Distinct responsibilities for User
sbldDistinctResp.Remove(0, sbldDistinctResp.Length);
xmlCase.Load(tmpPath + "\\SOD\\AllRespId.xml");
arrResps.Clear();
//Start preparing Responsibility selection criteria
RespNodes = xmlCase.SelectNodes("//row");
sRespCriteria = "";
if (RespNodes.Count > 0)
{
foreach (XmlNode RespNode in RespNodes)
{
string RespName = RespNode.Attributes.GetNamedItem("RespId").Value.ToString();
if (!arrResps.Contains(RespName))
{
arrResps.Add(RespName);
}
}
for (int i = 0; i < arrResps.Count; i++)
{
sbldDistinctResp.Append("(@RespId = '" + arrResps[i].ToString() + "') or ");
}
sbldDistinctResp.Remove(sbldDistinctResp.Length - 4, 4);
sRespCriteria = sbldDistinctResp.ToString();
if (!sRespCriteria.Equals(""))
{
sRespCriteria = "(" + sRespCriteria + ")";
}
}
File.Delete(tmpPath + "\\SOD\\AllRespId.xml");
我再说一遍,错误是随机发生的,即它有时会起作用,而不是在同一过程中的其他时间。
知道可能导致这种情况的原因以及如何解决?
答案 0 :(得分:0)
只有几点意见:
为什么要保存然后立即再次加载文件?实际上,为什么你甚至需要来保存这个文件 - 你已经在sbldDistinctResp
变量中获得了所需的所有信息来生成你需要使用的XML(如下所示) saveFile
在代码开头调用) - 难道你不能只复制它,用与saveFile
期间相同的XML包围它,并使用它吗?
“它随机发生”是一个非常主观的观察:)。您应该对此进行分析(例如,在循环中运行10,000次)并记录错误模式。你可能会感到惊讶的是,最初似乎随机的东西实际上在大量的运行中显示出清晰的模式。这可以帮助您在问题和服务器上的其他一些明显不相关的事件之间建立连接;或者它可以确认它确实是随机的,因此超出了你的控制范围。
如果你真的找不到问题并且你想要反病毒等等,那么你可以将加载代码包装在try / catch中并重试几次,如果你得到错误。它是hacky但它可以工作,假设你已经接受了初始错误是你无法控制的。