在调用ExitWindowsEx时使用EWX_FORCE参数试试
EWX_FORCE=4

解决方案 »

  1.   

    Win2000或者NT可以用 Net.exe session /delete 断开所有连接
      

  2.   

    '有没有简便的方法在VB中让MODEM断线?
    '我在程序中使用拨号网络中导出的DUN文件来拨号登录NT网,弹
    '出“连接到”窗口后,用SENDKEYS命令发送回车,进入拨号并且
    '登录,系统自动恢复网络驱动器映射(这之前是手工映射的,有
    '没有API命令执行网络映射的?),但往往映射还未完成程序就
    '继续下去,从而得到错误的结果。怎样才能一步步地完成拨号、
    '映射,然后才继续执行下面的程序呢?
    '回答:
    '要想控制拨号网络,就要使用Remote Access Service (RAS) API,这个API最早是在Windows for Workgroup 3.11中出现的,现在它已经成为Win32 API的一个组成部分。挂断拨号网络的函数叫RasHangUp,这个函数的功能和用法都很简单,它只有一个参数,就是要挂断的拨号网络连接的句柄。我们可以利用
    'RasEnumConnections获得当前系统所有RAS连接(通常我们的系统在一个时刻只使用一个拨号网络连接),利用这个函数我就可以得到RasHangUp所需的句柄了。不过RasEnumConnections函数在Windows 95和 Windows NT下的使用略有不同,限于篇幅我们只给出在Windows 95下调用该函数的例子。读者可以从Win32 API的手册找到所有相关函数的详细介绍,不过VB的WIN32API.TXT中没有包括RAS API所需的声明语句,我们在下面给出解决本问题需要的函数和结构声明。如果希望深入研究这个问题,可以访问参考QA000035 “在VB中如何实现自动启动拨号网络”,从中可以找到完整的RAS API声明和在Windows NT下调用RasEnumConnections函数的例子 。
    '为了运行下面这个例子,首先需要建立一个窗体,在窗体上放置一个按钮,然后输入以下语句:
    Option Explicit
    Private Declare Function RasHangUp Lib "RasApi32.DLL" Alias "RasHangUpA" (ByVal hRasConn As Long) As Long
    Private Declare Function RasEnumConnections Lib "RasApi32.DLL" Alias "RasEnumConnectionsA" (lprasconn As Any, lpcb As Long, lpcConnections As Long) As LongConst RAS95_MaxEntryName = 256
    Const RAS95_MaxDeviceName = 128
    Const RAS_MaxDeviceType = 16Private Type RASCONN95
        'set dwsize to 412
        dwSize As Long
        hRasConn As Long
        szEntryName(RAS95_MaxEntryName) As Byte
        szDeviceType(RAS_MaxDeviceType) As Byte
        szDeviceName(RAS95_MaxDeviceName) As Byte
    End TypePrivate Sub Command1_Click()
     Dim lngRetCode As Long
     Dim lpcb As Long
     Dim lpcConnections As Long
     Dim intArraySize As Integer
     Dim intLooper As Integer ReDim lprasconn95(intArraySize) As RASCONN95
     lprasconn95(0).dwSize = 412
     lpcb = 256 * lprasconn95(0).dwSize
     lngRetCode = RasEnumConnections(lprasconn95(0), lpcb, lpcConnections) If lngRetCode = 0 Then
        If lpcConnections > 0 Then
            For intLooper = 0 To lpcConnections - 1
            RasHangUp lprasconn95(intLooper).hRasConn
            Next intLooper
        Else
            MsgBox "没有拨号网络连接!", vbInformation
        End If
     End If
    End Sub
    '运行时,按下按钮就可以断开拨号网络的连接。
      

  3.   

    断开与Internet的连接声明:
    Public Const RAS_MAXENTRYNAME As Integer = 256
    Public Const RAS_MAXDEVICETYPE As Integer = 16
    Public Const RAS_MAXDEVICENAME As Integer = 128
    Public Const RAS_RASCONNSIZE As Integer = 412Public Type RasEntryName
    dwSize As Long
    szEntryName(RAS_MAXENTRYNAME) As Byte
    End TypePublic Type RasConn
    dwSize As Long
    hRasConn As Long
    szEntryName(RAS_MAXENTRYNAME) As Byte
    szDeviceType(RAS_MAXDEVICETYPE) As Byte
    szDeviceName(RAS_MAXDEVICENAME) As Byte
    End TypePublic Declare Function RasEnumConnections Lib _
    "rasapi32.dll" Alias "RasEnumConnectionsA" (lpRasConn As _
    Any, lpcb As Long, lpcConnections As Long) As LongPublic Declare Function RasHangUp Lib "rasapi32.dll" Alias _
    "RasHangUpA" (ByVal hRasConn As Long) As Long 
    Public gstrISPName As String
    Public ReturnCode As Long函数:
    Public Sub HangUp()
    Dim i As Long
    Dim lpRasConn(255) As RasConn
    Dim lpcb As Long
    Dim lpcConnections As Long
    Dim hRasConn As Long
    lpRasConn(0).dwSize = RAS_RASCONNSIZE
    lpcb = RAS_MAXENTRYNAME * lpRasConn(0).dwSize
    lpcConnections = 0
    ReturnCode = RasEnumConnections(lpRasConn(0), lpcb, _
    lpcConnections)If ReturnCode = ERROR_SUCCESS Then
    For i = 0 To lpcConnections - 1
    If Trim(ByteToString(lpRasConn(i).szEntryName)) _
    = Trim(gstrISPName) Then
    hRasConn = lpRasConn(i).hRasConn
    ReturnCode = RasHangUp(ByVal hRasConn)
    End If
    Next i
    End IfEnd SubPublic Function ByteToString(bytString() As Byte) As String
    Dim i As Integer
    ByteToString = ""
    i = 0
    While bytString(i) = 0&
    ByteToString = ByteToString & Chr(bytString(i))
    i = i + 1
    Wend
    End Function
      

  4.   

    msgbox "uguess(uguess) is right",vbokonly