ManagementException:WMI异常处理介绍

    .NET调用WMI后无论是同步调用还是异步调用,都会产生返回一个int类型的执行结果。如果成功,则返回0。如果不是0,则有对应错误码表示发生了什么错误。

根据咱们这个系列的博文,我总结了关于进程,服务,目录和共享四种异常的错误码。

CheckExceptionClass类是异常检查类,所有WMI执行后,都要执行这个类里面的相关方法进行状态检测,以确保执行成功。代码如下:

using System;
using System.Collections.Generic;
using System.Text;
using TJVictor.WMI.WmiException;

namespace TJVictor.WMI
{
    class CheckExceptionClass
    {
        public static void CheckDirectoryExcepton(int exceptionCode)
        {
            if (!exceptionCode.Equals(0))
                throw new DirectoryException(exceptionCode);
        }

        public static void CheckProcessException(int exceptionCode)
        {
            if (!exceptionCode.Equals(0))
                throw new ProcessException(exceptionCode);
        }

        public static void CheckServiceException(int exceptionCode)
        {
            if (!exceptionCode.Equals(0))
                throw new ServiceException(exceptionCode);
        }

        public static void CheckShareException(int exceptionCode)
        {
            //if (!exceptionCode.Equals(0))
            //    throw new IICV2WmiAccess.WmiException.ShareException(exceptionCode);
        }
    }
}



 

ProcessException类是进程异常类。代码如下:
using System;
using System.Collections.Generic;
using System.Text;
using System.Management;

namespace TJVictor.WMI.WmiException
{
    /// 
    /// The Create method creates a new process. 
    /// The method returns an integer value that can be interpretted as follows: 
    /// 0 - Successful completion.
    /// 2 - The user does not have access to the requested information.
    /// 3 - The user does not have sufficient privilge.
    /// 8 - Unknown failure.
    /// 9 - The path specified does not exist.
    /// 21 - The specified parameter is invalid.
    /// Other - For integer values other than those listed above, refer to Win32 error code documentation.
    /// 
    public class ProcessException : ManagementException
    {
        public new string Message;
        public ProcessException(int errorCode)
            : base()
        {
            switch (errorCode)
            {
                case 2: Message = "The user does not have access to the requested information."; break;
                case 3: Message = "The user does not have sufficient privilge."; break;
                case 8: Message = "Unknown failure."; break;
                case 9: Message = "The path specified does not exist."; break;
                case 21: Message = "The specified parameter is invalid."; break;
                default: Message = "Unknown failure."; break;
            }
        }

        public ProcessException(string message)
            : base()
        {
            this.Message = message;
        }
    }
}



 

ServiceException类是服务异常类。代码如下:
using System;
using System.Collections.Generic;
using System.Text;
using System.Management;

namespace TJVictor.WMI.WmiException
{
    /// 
    /// 0 - The request was accepted.
    /// 1 - The request is not supported.
    /// 2 - The user did not have the necessary access.
    /// 3 - The service cannot be stopped because other services that are running are dependent on it.
    /// 4 - The requested control code is not valid, or it is unacceptable to the service.
    /// 5 - The requested control code cannot be sent to the service because the state of the service (Win32_BaseService:State) is equal to 0, 1, or 2.
    /// 6 - The service has not been started.
    /// 7 - The service did not respond to the start request in a timely fashion.
    /// 8 - Unknown failure when starting the service.
    /// 9 - The directory path to the service executable was not found.
    /// 10 - The service is already running.
    /// 11 - The database to add a new service is locked.
    /// 12 - A dependency for which this service relies on has been removed from the system.
    /// 13 - The service failed to find the service needed from a dependent service.
    /// 14 - The service has been disabled from the system.
    /// 15 - The service does not have the correct authentication to run on the system.
    /// 16 - This service is being removed from the system.
    /// 17 - There is no execution thread for the service.
    /// 18 - There are circular dependencies when starting the service.
    /// 19 - There is a service running under the same name.
    /// 20 - There are invalid characters in the name of the service.
    /// 21 - Invalid parameters have been passed to the service.
    /// 22 - The account, which this service is to run under is either invalid or lacks the permissions to run the service.
    /// 23 - The service exists in the database of services available from the system.
    /// 24 - The service is currently paused in the system.
    /// Other - For integer values other than those listed above, refer to Win32 error code documentation.
    /// 
    public class ServiceException : ManagementException
    {
        public new string Message;
        public ServiceException(int errorCode)
            : base()
        {
            switch (errorCode)
            {
                case 0: Message = "The request was accepted."; break;
                case 1: Message = "The request is not supported."; break;
                case 2: Message = "The user did not have the necessary access."; break;
                case 3: Message = "The service cannot be stopped because other services that are running are dependent on it."; break;
                case 4: Message = "The requested control code is not valid, or it is unacceptable to the service."; break;
                case 5: Message = "The service is already stopped."; break;
                case 6: Message = "The service has not been started."; break;
                case 7: Message = "The service did not respond to the start request in a timely fashion."; break;
                case 8: Message = "Unknown failure when starting the service."; break;
                case 9: Message = "The directory path to the service executable was not found."; break;
                case 10: Message = "The service is already running."; break;
                case 11: Message = "The database to add a new service is locked."; break;
                case 12: Message = "A dependency for which this service relies on has been removed from the system."; break;
                case 13: Message = "The service failed to find the service needed from a dependent service."; break;
                case 14: Message = "The service has been disabled from the system."; break;
                case 15: Message = "The service does not have the correct authentication to run on the system."; break;
                case 16: Message = "This service is being removed from the system."; break;
                case 17: Message = "There is no execution thread for the service."; break;
                case 18: Message = "There are circular dependencies when starting the service."; break;
                case 19: Message = "There is a service running under the same name."; break;
                case 20: Message = "There are invalid characters in the name of the service."; break;
                case 21: Message = "Invalid parameters have been passed to the service."; break;
                case 22: Message = "The account, which this service is to run under is either invalid or lacks the permissions to run the service."; break;
                case 23: Message = "The service exists in the database of services available from the system."; break;
                case 24: Message = "The service is currently paused in the system."; break;
                default: Message = "Unknown failure."; break;
            }
        }

        public ServiceException(string message)
            : base()
        {
            this.Message = message;
        }
    }
}



 

DirectoryException类是目录异常类。代码如下:
using System;
using System.Collections.Generic;
using System.Text;
using System.Management;

namespace TJVictor.WMI.WmiException
{
    /// 
    /// 0 - The request was successful.
    /// 2 - Access was denied.
    /// 8 - An unspecified failure occurred.
    /// 9 - The name specified was invalid.
    /// 10 - The object specified already exists.
    /// 11 - The file system is not NTFS.
    /// 12 - The platform is not Windows NT or Windows 2000.
    /// 13 - The drive is not the same.
    /// 14 - The directory is not empty.
    /// 15 - There has been a sharing violation.
    /// 16 - The start file specified was invalid.
    /// 17 - A privilege required for the operation is not held.
    /// 21 - A parameter specified is invalid.
    /// 
    public class DirectoryException : ManagementException
    {
        public new string Message;
        public DirectoryException(int errorCode)
            : base()
        {
            switch (errorCode)
            {
                case 2: Message = "Access was denied."; break;
                case 8: Message = "An unspecified failure occurred."; break;
                case 9: Message = "The name specified was invalid."; break;
                case 10: Message = "The object specified already exists."; break;
                case 11: Message = "The file system is not NTFS."; break;
                case 12: Message = "The platform is not Windows NT or Windows 2000."; break;
                case 13: Message = "The drive is not the same."; break;
                case 14: Message = "The directory is not empty."; break;
                case 15: Message = "There has been a sharing violation."; break;
                case 16: Message = "The start file specified was invalid."; break;
                case 17: Message = "A privilege required for the operation is not held."; break;
                case 21: Message = "A parameter specified is invalid."; break;
                default: Message = "Unknown failure."; break;
            }
        }

        public DirectoryException(string message)
            : base()
        {
            Message = message;
        }
    }
}



 

ShareException类是共享异常类。代码如下:
using System;
using System.Collections.Generic;
using System.Text;
using System.Management;

namespace TJVictor.WMI.WmiException
{
    /// 
    /// 0 - Successful completion.
    /// 2 - The user does not have access to the requested information.
    /// 8 - Unknown failure.
    /// 9 - The character or file system name is invalid.
    /// 10 - The value specified for the level parameter is invalid. 
    /// 21 - The specified parameter is invalid.
    /// 22 - The share name is already in use on this server.
    /// 23 - The operation is invalid for a redirected resource. The specified device name is assigned to a shared resource.
    /// 24 - The device or directory does not exist.
    /// 25 - The share name does not exist.
    /// Other - For integer values other than those listed above, refer to Win32 error code documentation.
    /// 
    public class ShareException : ManagementException
    {
        public new string Message;
        public ShareException(int errorCode)
            : base()
        {
            switch (errorCode)
            {
                case 2: Message = "The user does not have access to the requested information."; break;
                case 8: Message = "Unknown failure."; break;
                case 9: Message = "The character or file system name is invalid."; break;
                case 10: Message = "The value specified for the level parameter is invalid. "; break;
                case 21: Message = "The specified parameter is invalid."; break;
                case 22: Message = "The share name is already in use on this server."; break;
                case 23: Message = "The operation is invalid for a redirected resource. The specified device name is assigned to a shared resource."; break;
                case 24: Message = "The device or directory does not exist."; break;
                case 25: Message = "The share name does not exist."; break;
                default: Message = "For integer values other than those listed above, refer to Win32 error code documentation."; break;
            }
        }

        public ShareException(string message)
            : base()
        {
            this.Message = message;
        }
    }
}



 

关于这个类的使用方法,我在介绍使用WMI控制进程、服务、目录、共享的代码中都有体现。这里不再对其使用方法做过多的介绍。 
其实异常类的错误代码可以在MSDN中找到,这里不再一一列举。
原文地址:https://www.cnblogs.com/tianma3798/p/3560620.html