我的任务是找出造成这段代码问题的原因:
public static ArrayList GetEthernetMacAddresses()
{
ArrayList addresses = new ArrayList();
ManagementClass mc = new ManagementClass("Win32_NetworkAdapter");
// This causes GetInstances(options)
// to return all subclasses of Win32_NetworkAdapter
EnumerationOptions options = new EnumerationOptions();
options.EnumerateDeep = true;
foreach (ManagementObject mo in mc.GetInstances(options)) {
string macAddr = mo["MACAddress"] as string;
string adapterType = mo["AdapterType"] as string;
if (!StringUtil.IsBlank(macAddr) && !StringUtil.IsBlank(adapterType))
{
if (adapterType.StartsWith("Ethernet")) {
addresses.Add(macAddr);
}
}
}
return addresses;
}
在我们的(Win2003)虚拟服务器上,这在作为控制台应用程序的一部分运行时有效,但不能在IIS上运行的Web服务(在同一台机器上)运行。
或者,我可以在IIS上的Web服务中使用此代码(在虚拟服务器上)并获取正确的返回值:
public static string GetMacAddresses()
{
ManagementClass mgmt = new ManagementClass(
"Win32_NetworkAdapterConfiguration"
);
ManagementObjectCollection objCol = mgmt.GetInstances();
foreach (ManagementObject obj in objCol)
{
if ((bool)obj["IPEnabled"])
{
if (sb.Length > 0)
{
sb.Append(";");
}
sb.Append(obj["MacAddress"].ToString());
}
obj.Dispose();
}
}
为什么第二个工作而不是第一个工作?
为什么只有通过虚拟机上的IIS Web服务调用?
任何帮助都将不胜感激。
更新:经过大量电话时间与所有不同级别的MS支持,我们得出的结论是“按设计”。
由于它位于虚拟网络适配器驱动程序的驱动程序级别,答案是我们应该更改代码“以解决问题”。
这意味着您无法在虚拟服务器上使用可靠的测试代码,除非您使用与在物理服务器上使用的代码相同的代码,因为我们无法保证服务器是完全相同的副本...
答案 0 :(得分:1)
好的,所以我写了这段代码来测试这个问题:
public void GetWin32_NetworkAdapter()
{
DataTable dt = new DataTable();
dt.Columns.Add("AdapterName", typeof(string));
dt.Columns.Add("ServiceName", typeof(string));
dt.Columns.Add("AdapterType", typeof(string));
dt.Columns.Add("IPEnabled", typeof(bool));
dt.Columns.Add("MacAddress", typeof(string));
//Try getting it by Win32_NetworkAdapterConfiguration
ManagementClass mgmt = new ManagementClass("Win32_NetworkAdapter");
EnumerationOptions options = new EnumerationOptions();
options.EnumerateDeep = true;
ManagementObjectCollection objCol = mgmt.GetInstances(options);
foreach (ManagementObject obj in objCol)
{
DataRow dr = dt.NewRow();
dr["AdapterName"] = obj["Caption"].ToString();
dr["ServiceName"] = obj["ServiceName"].ToString();
dr["AdapterType"] = obj["AdapterType"];
dr["IPEnabled"] = (bool)obj["IPEnabled"];
if (obj["MacAddress"] != null)
{
dr["MacAddress"] = obj["MacAddress"].ToString();
}
else
{
dr["MacAddress"] = "none";
}
dt.Rows.Add(dr);
}
gvConfig.DataSource = dt;
gvConfig.DataBind();
}
当它在物理IIS盒上运行时,我得到了这个: Physical IIS server http://img14.imageshack.us/img14/8098/physicaloutput.gif
虚拟IIS服务器上的相同代码: Virtual server http://img25.imageshack.us/img25/4391/virtualoutput.gif
看到差异?这是第一行。虚拟服务器不返回“AdapterType”字符串。这就是原始代码失败的原因。
这引出了一个有趣的想法。如果虚拟服务器应该是真实IIS服务器的“虚拟”表示,为什么它不返回相同的值?
答案 1 :(得分:0)
为什么两者会有不同的结果?由于用户帐户不同,您可能会从控制台和服务中获得不同的结果。
为什么(1)失败而(2)工作? adapterType的null结果是否可能返回null值?如果是这样,代码会处理这种情况吗?