Access编程交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

行业

MRP/ERP管理系统
进销存管理

采购管理

仓库管理

销售管理

人力资源管理(HRM)

人事管理

工资管理

考勤管理

CRM管理
BPR/流程优化
其它企业管理
营销理念
团队建设
程序人生
软件工程

需求工程

项目管理

软件测试

软件文档

热门文章

  • 怎么把小写人民币转换为大写..
  • Yahoo!创办人--杨致..
  • 关于邮件群发系统的营销定位
  • 点数是什么
  • 一个中专生的程序员之路
  • 从学生到程序员

最新文章

  • 浅谈Access开发(一)
  • 使用准则进行条件查询--1..
  • Access保留字&变量名..
  • access下如何恢复已经..
  • 软件开发进度管理的四个问题
  • 项目进度控制学习体会

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 行业 > 程序人生
程序人生

关机代码小全(推荐)

----------------------C语言的-----------------------------------
//Shutdown the machine

#include
#include

void main()
{
            HANDLE hToken;
            TOKEN_PRIVILEGES tkp;
            if(!OpenProcessToken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES|TOKEN_QUERY,&hToken))
            return;
            LookupPrivilegeValue(NULL,SE_SHUTDOWN_NAME,&tkp.Privileges[0].Luid);
            tkp.PrivilegeCount=1;
            tkp.Privileges[0].Attributes=SE_PRIVILEGE_ENABLED;
            AdjustTokenPrivileges(hToken,FALSE,&tkp,0,(PTOKEN_PRIVILEGES)NULL,0);

      
    InitiateSystemShutdown(
        NULL,
        NULL,
        0,
        TRUE,
        FALSE         
        );

}

---------------VBS的---------------------
CreateObject("WScript.Shell"access数据库.SendKeys "^{ESC}u{down}{down}{up}~"


---------------VB的------------------------
VB 的WINAPI调用
-------------- 定义~~~ N多~~~ ------------------------
'API FOR CLOSE WINDOWS
Const TOKEN_QUERY As Long = &H8&
Const TOKEN_ADJUST_PRIVILEGES As Long = &H20&
Const SE_PRIVILEGE_ENABLED As Long = &H2
Const SE_RESTORE_NAME = "SeRestorePrivilege" 'Important for what we're trying to accomplish
Const SE_BACKUP_NAME = "SeBackupPrivilege"
Const REG_FORCE_RESTORE As Long = 8& ' Almost as import, will allow you to restore over a key while it's open!
Const READ_CONTROL = &H20000
Const SYNCHRONIZE = &H100000
Const STANDARD_RIGHTS_READ = (READ_CONTROL)
Const STANDARD_RIGHTS_WRITE = (READ_CONTROL)
Const STANDARD_RIGHTS_ALL = &H1F0000
Const SPECIFIC_RIGHTS_ALL = &HFFFF
Const KEY_QUERY_VALUE = &H1
Const KEY_SET_VALUE = &H2
Const KEY_CREATE_SUB_KEY = &H4
Const KEY_ENUMERATE_SUB_KEYS = &H8
Const KEY_NOTIFY = &H10
Const KEY_CREATE_LINK = &H20
Const KEY_READ = ((STANDARD_RIGHTS_READ Or KEY_QUERY_VALUE Or KEY_ENUMERATE_SUB_KEYS Or KEY_NOTIFY) And (Not SYNCHRONIZE))
Const KEY_ALL_ACCESS = ((STANDARD_RIGHTS_ALL Or KEY_QUERY_VALUE Or KEY_SET_VALUE Or KEY_CREATE_SUB_KEY Or KEY_ENUMERATE_SUB_KEYS Or KEY_NOTIFY Or KEY_CREATE_LINK) And (Not SYNCHRONIZE))

Private Type LUID
UsedPart As Long
IgnoredForNowHigh32BitPart As Long
End Type

Private Type TOKEN_PRIVILEGES
PrivilegeCount As Long
TheLuid As LUID
Attributes As Long
End Type

Public Declare Function ExitWindowsEx Lib "user32" (ByVal dwOptions As Long, ByVal dwReserved As Long) As Long
Private Declare Function LookupPrivilegeValue Lib "advapi32" Alias "LookupPrivilegeValueA" (ByVal lpSystemName As String, ByVal lpName As String, lpLuid As LUID) As Long
Private Declare Function AdjustTokenPrivileges Lib "advapi32" (ByVal TokenHandle As Long, ByVal DisableAllPrivileges As Long, NewState As TOKEN_PRIVILEGES, ByVal BufferLength As Long, PreviousState As TOKEN_PRIVILEGES, ReturnLength As Long) As Long
Private Const EWX_SHUTDOWN As Long = 1
Private Const EWX_FORCE As Long = 4
Private Const EWX_REBOOT = 2
Private Const EWX_LOGOFF = 0

Public Sub AdjustToken()
Const TOKEN_ADJUST_PRIVILEGES = &H20
Const TOKEN_QUERY = &H8
Const SE_PRIVILEGE_ENABLED = &H2
Dim hdlProcessHandle As Long
Dim hdlTokenHandle As Long
Dim tmpLuid As LUID
Dim tkp As TOKEN_PRIVILEGES
Dim tkpNewButIgnored As TOKEN_PRIVILEGES
Dim lBufferNeeded As Long

hdlProcessHandle = GetCurrentProcess()
OpenProcessToken hdlProcessHandle, (TOKEN_ADJUST_PRIVILEGES Or _
TOKEN_QUERY), hdlTokenHandle

' Get the LUID for shutdown privilege.
LookupPrivilegeValue "", "SeShutdownPrivilege", tmpLuid

tkp.PrivilegeCount = 1 ' One privilege to set
tkp.TheLuid = tmpLuid
tkp.Attributes = KEY_ALL_ACCESS

' Enable the shutdown privilege in the access token of this process.
AdjustTokenPrivileges hdlTokenHandle, False, _
tkp, Len(tkpNewButIgnored), tkpNewButIgnored, lBufferNeeded

End Sub

Public Sub ShutDown()
ExitWindowsEx (EWX_FORCE Or EWX_SHUTDOWN), &HFFFF
End Sub

Public Sub ReStart()
ExitWindowsEx (EWX_FORCE Or EWX_REBOOT), &HFFFF
End Sub
Public Sub LOGOFF()
ExitWindowsEx (EWX_LOGOFF Or EWX_FORCE), &HFFFF
End Sub

----------------------------- 使用方法 -------------------------
call AdjustToken()
call ShutDown()

WINNT/2K/XP 需要call AdjustToken(),几乎在所有WINDOWS下都能用吧
EWX_FORCE 是强制~~ 不用这个的话将等待

----------------DELPHI的------------------
{********************重启,关机,强力关机,注销********************}
function Irc_Reboot_Shutdown(i:integer):boolean;
var
hToken :THandle;
tkp : TOKEN_PRIVILEGES;
ReturnLength : DWord;
begin
RESULT:=false;
if (not OpenProcessToken(GetCurrentProcess(),
TOKEN_ADJUST_PRIVILEGES
or TOKEN_ALL_ACCESS
or TOKEN_QUERY, hToken))
then
RESULT:=false;
LookupPrivilegeValue(nil,'SeShutdownPrivilege',tkp.Privileges[0].Luid);
tkp.PrivilegeCount := 1;
tkp.Privileges[0].Attributes :=SE_PRIVILEGE_ENABLED;
ReturnLength :=0;
AdjustTokenPrivileges(hToken, FALSE, tkp, 0,nil,ReturnLength);

if (GetLastError() <> ERROR_SUCCESS) then
RESULT:=false;
case i of
1: begin
ExitWindowsEx(EWX_REBOOT, 0); //reboot
RESULT:=true;
end;
2: begin
ExitWindowsEx(EWX_SHUTDOWN, 0); //shutdown
RESULT:=true;
end;
3: begin
ExitWindowsEx(EWX_FORCE+EWX_SHUTDOWN, 0); //force shutdown
RESULT:=true;
end;
4: begin
ExitWindowsEx(EWX_LOGOFF, 0); //logoff
RESULT:=true;
end;
end;

end;
发布人:佚名-稳健风云  
分享到:
点击次数:  更新时间:2004-05-25 10:13:40  【打印此页】  【关闭】
上一条:如何打开需要用户组的*.mdb文件  下一条:为什么我在网络编程时不能同查三个以上的表呀



相关文章

  • • 浅谈Access开发(一)
  • • 使用准则进行条件查询--1.5.常用的准则表达式
  • • Access保留字&变量名列表
  • • access下如何恢复已经删除的记录;如何恢复已经删除的表、窗体等
  • • 软件开发进度管理的四个问题
  • • 项目进度控制学习体会
  • • 判断项目成败的六个要素
  • • 要实施ITIL必须管理好期望

热门文章

  • [2004-01-17] 点数啊access数据库
  • [2004-04-13] 下拉式菜单access数据库
  • [2003-12-14] 燕赵都市报平乡县发行部招聘广告access数据库
  • [2003-12-12] 报业营销人员培训实战access数据库
  • [2003-12-13] 关于邮件群发系统的营销定位access数据库
  • [2006-11-15] 软件开发进度管理的四个问题access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

中山市天鸣科技发展有限公司 版权所有 1999-2023 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2025  www.metinfo.cn