实现98/2000/XP下的休眠和关机

【简 介】
  实现休眠功能很简单,只要在任意想要执行的地方执行如下给出的休眠函数SetPower()就行,其实休眠很简单,只需要API:SetSystemPowerState()就行,就如关机/注销/重启一样,只需要ExitWindowEx(),但这些API可以直接用在98下,却不能用在2000/XP中,因为这里牵涉到了用户权限,没有权限是不能进行这些操作的,所以,首先要取得权限,下面给出代码:   

       实现休眠功能很简单,只要在任意想要执行的地方执行如下给出的休眠函数SetPower()就行,其实休眠很简单,只需要API:SetSystemPowerState()就行,就如关机/注销/重启一样,只需要ExitWindowEx(),但这些API可以直接用在98下,却不能用在2000/XP中,因为这里牵涉到了用户权限,没有权限是不能进行这些操作的,所以,首先要取得权限,下面给出代码:

    #define RTN_ERROR 13

    void PERR(LPTSTR szAPI, DWORD dwLastError) //休眠时调用到的一个函数,用来

    ////记录休眠中遇到的错误

    {

    LPTSTR MessageBuffer;

    DWORD dwBufferLength;

    fprintf(stderr,"%s error! (rc=%lu)/n", szAPI, dwLastError);

    if(dwBufferLength=FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER  

    FORMAT_MESSAGE_FROM_SYSTEM,

    NULL,

    dwLastError,

    LANG_NEUTRAL,

    (LPTSTR) &MessageBuffer,

    0,

    NULL))

    {

    DWORD dwBytesWritten;

    WriteFile(GetStdHandle(STD_ERROR_HANDLE),

    MessageBuffer,

    dwBufferLength,

    &dwBytesWritten,

    NULL);

    LocalFree(MessageBuffer);

    }

    }

    INT SetPower()有//主要功能函数

    {

    TOKEN_PRIVILEGES tp;

    HANDLE hToken;

    LUID luid;

    LPTSTR MachineName=NULL;

    if(!OpenProcessToken(GetCurrentProcess(), ////////从这里////////////////////////////

    TOKEN_ADJUST_PRIVILEGES,

    &hToken ))

    {

    PERR("OpenProcessToken", GetLastError() );

    return RTN_ERROR;

    }

    if(!LookupPrivilegeValue(MachineName, SE_SHUTDOWN_NAME, &luid))

    {

    PERR("LookupPrivilegeValue", GetLastError() );

    return RTN_ERROR;

    }

    tp.PrivilegeCount = 1;

    tp.Privileges[0].Luid = luid;

    tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;

    AdjustTokenPrivileges(hToken, FALSE, &tp, sizeof(TOKEN_PRIVILEGES),

    NULL, NULL ); ////////////////到这里,是取得权限//////////////////////

    SetSystemPowerState(FALSE,TRUE);

    return 0;

    }

  这样,在任意需要休眠的时候调用SetPower();即可休眠,但是有一点要注意:必须打开了高级电源管理的休眠支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章