当前位置:首页 > > 充电吧
[导读]C++ (MFC)开机自启动源码(修改注册表) 分类: 2010-01-14 10:28 287人阅读 评论(0) 收藏 举报 CString   str; //添加注册表路径 //WCHAR*   

C++ (MFC)开机自启动源码(修改注册表)
分类: 2010-01-14 10:28 287人阅读 评论(0) 收藏 举报
CString   str; //添加注册表路径
//WCHAR*     CurrentPath=(WCHAR*)malloc(sizeof(char)*100);//程序当前路径
WCHAR*     CurrentPath= new WCHAR[sizeof(WCHAR)*100];//程序当前路径
HKEY   hRegKey;   //注册key
BOOL   bResult;   //打开注册表返回值
str=_T("Software//Microsoft//Windows//CurrentVersion//Run");//注册表  
GetModuleFileName(NULL,CurrentPath,MAX_PATH); //获得运用程序路径
if(bResult=RegOpenKey(HKEY_LOCAL_MACHINE,   str,   &hRegKey)   !=   ERROR_SUCCESS)//打开注册表    
{  
   //free(CurrentPath); //打开不成功就释放内存并返回
   delete[] CurrentPath;
   return;  
}  
if(bResult=::RegSetValueEx(hRegKey,_T("StarBySelf"),0,REG_SZ,  
   (const   unsigned   char   *)CurrentPath,  
   MAX_PATH)!=   ERROR_SUCCESS)   //打开成功写信息到注册表
{   //写入失败
   RegCloseKey(hRegKey);   //关闭注册表key
//   free(CurrentPath);   //释放内存资源
   delete[] CurrentPath;
   return;   //返回
}  
//成功后执行释放内存
RegCloseKey(hRegKey);  
// free(CurrentPath);
delete[] CurrentPath;

 

 

 


MFC怎样编写后台运行的程序


以下为转载---------
1、实现开机自运行

     我在csdn网站上经常看到有人问这样的问题,其实要实现开机时就自动运行自己的程序并不难。在注册表的HKEY_LOCAL_MACHINE/Software/Microsoft/Windows/CurrentVersion/Run键下可以看到有一系列键值,它们都是开机自动运行的软件的路径。那么我们要做的就是编程实现将我们的程序的路径也添加到这个键值下,就搞定了。著名的“windows优化大师”也就是用去掉不必要的开机运行软件这个方法来实现开机速度优化的。
     既然要读写注册表,就要用到两个重要的操作注册表的函数:RegOpenKey()和RegSetValueEx()。前者用于打开注册表的键,后者则为打开的键设置键值,至于这两个API函数的具体参数,请参见MSDN。为了代码重用的要求,我为此封装了一个专门的函数,如下所示:

BOOL SetAutoRun(CString strPath)//开机自动运行
{
    CString str;
    HKEY hRegKey;
    BOOL bResult;
    str=_T("Software//Microsoft//Windows//CurrentVersion//Run");
    if(RegOpenKey(HKEY_LOCAL_MACHINE, str, &hRegKey) != ERROR_SUCCESS)
        bResult=FALSE;
    else
    {
        _splitpath(strPath.GetBuffer(0),NULL,NULL,str.GetBufferSetLength(MAX_PATH+1),NULL);
        strPath.ReleaseBuffer();
        str.ReleaseBuffer();
        if(::RegSetValueEx( hRegKey,
                            str,
                            0,
                            REG_SZ,
                            (CONST BYTE *)strPath.GetBuffer(0),
                            strPath.GetLength() ) != ERROR_SUCCESS)
           bResult=FALSE;
        else
           bResult=TRUE;
        strPath.ReleaseBuffer();
    }
    return bResult;
}

     其中strPath参数表示要设置为自运行的程序的绝对路径。当设置成功时返回true,否则返回false。
这里又带来一个问题:既然需要本程序的绝对路径,那么怎么得到它呢?总不能指定一个值吧,那么当本程序的路径改变时就又要修改程序,太麻烦了。可以用这个封装的函数来实现:
//得到程序文件本身的路径(包括文件名)

CString GetMyPath()
{
    CString strPath;
    GetModuleFileName(NULL,strPath.GetBufferSetLength(MAX_PATH+1),MAX_PATH);
    strPath.ReleaseBuffer();
    return strPath;
}


2、实现运行时自动隐藏

    这是一个很有趣很古老的话题,csdn上经常有人为此讨论不休,提出不少方案,比如在对话框的OnInitDialog()中添加一句:ShowWindow(SW_HIDE);,或者在对话框属性框中去掉对话框的Visible属性;或者将对话框移到桌面以外的地方去;或者首先将对话框最小化,然后实现最小化时隐藏……有趣的是这些很容易想到的常规方法都不能解决这个问题,或者说解决的不够好。我通过查找相关文章和多次修改代码,找出了真正解决这个问题的办法。
    之所以用ShowWindow()函数失效,我认为可能是对话框的DoModal()在作怪,这么一来就只能绕开DoModal(),那么就自然想到可以把对话框变成一个无模式对话框。无模式对话框平时我们用到的不多,它与模式对话框不同,是用Create方法Create出来的,而不是DoModal()创建的。
    假设建立一个VC.NET工程GetTime,首先在CGetTimeApp类中添加一个成员变量:CGetTimeDlg *dlg;然后在InitInstance()中将原来的:

     int nResponse = dlg.DoModal();
     if (nResponse == IDOK)
     {
        // TODO: Place code here to handle when the dialog is
        //   dismissed with OK
     }
     else if (nResponse == IDCANCEL)
     {
        // TODO: Place code here to handle when the dialog is
        //   dismissed with Cancel
     }
以及return FALSE;全部删除掉,改为:      dlg=new CGetTimeDlg;
     m_pMainWnd = dlg;
     return dlg->Create(IDD_GETTIME_DIALOG);
    最后别忘了在ExitInstance()中加上一句:delete dlg;好了,这下把本程序的对话框变成了一个无模式对话框。不过既然是无模式对话框,就不能再用OnOK(),OnCancel()来退出了,要用DestroyWindow()。
    由于在上面的代码中没有将对话框设为可见,所以运行时就实现了隐藏,而且在Windows任务栏上也没有显示。至此,第二个问题得到完美解决。

 

 

 

 

 

 

 


一、当前用户专有的启动文件夹  
这是许多应用软件自动启动的常用位置,Windows自动启动放入该文件夹的所有快捷方式。用户启动文件夹一般在:/Documents and Settings/

二、对所有用户有效的启动文件夹   
这是寻找自动启动程序的第二个重要位置,不管用户用什么身份登录系统,放入该文件夹的快捷方式总是自动启动——这是它与用户专有的启动文件夹的区别所在。该文件夹一般在:/Documents and Settings/All Users/「开始」菜单/程序/启动。   

三、Load注册键   
介绍该注册键的资料不多,实际上它也能够自动启动程序。位置:HKEY_CURRENT_USER/Software/Microsoft/WindowsNT/CurrentVersion/Windows/load。

四、Userinit注册键   
位置:HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/WindowsNT/CurrentVersion/Winlogon/Userinit。这里也能够使系统启动时自动初始化程序。通常该注册键下面有一个userinit.exe,如图一,但这个键允许指定用逗号分隔的多个程序,例如“userinit.exe,OSA.exe”(不含引号)。

五、Explorer/Run注册键   
和load、Userinit不同,Explorer/Run键在HKEY_CURRENT_USER和HKEY_LOCAL_MACHINE下都有,具体位置是:HKEY_CURRENT_USER/Software/Microsoft/Windows/CurrentVersion/Policies/Explorer/Run,和HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/Policies/Explorer/Run。   

六、RunServicesOnce注册键   
RunServicesOnce注册键用来启动服务程序,启动时间在用户登录之前,而且先于其他通过注册键启动的程序。RunServicesOnce注册键的位置是:HKEY_CURRENT_USER/Software/Microsoft/Windows/CurrentVersion/RunServicesOnce,和HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/RunServicesOnce。

七、RunServices注册键   
RunServices注册键指定的程序紧接RunServicesOnce指定的程序之后运行,但两者都在用户登录之前。RunServices的位置是:HKEY_CURRENT_USER/Software/Microsoft/Windows/CurrentVersion/RunServices,和HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/RunServices。

八、RunOnce/Setup注册键   
RunOnce/Setup指定了用户登录之后运行的程序,它的位置是:HKEY_CURRENT_USER/Software/Microsoft/Windows/CurrentVersion/RunOnce/Setup,和HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/RunOnce/Setup。

九、RunOnce注册键   
安装程序通常用RunOnce键自动运行程序,它的位置在HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/RunOnce和HKEY_CURRENT_USER/Software/Microsoft/Windows/CurrentVersion/RunOnce。HKEY_LOCAL_MACHINE下面的RunOnce键会在用户登录之后立即运行程序,运行时机在其他Run键指定的程序之前。HKEY_CURRENT_USER下面的RunOnce键在操作系统处理其他Run键以及“启动”文件夹的内容之后运行。如果是XP,你还需要检查一下HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/RunOnceEx。

十、Run注册键   
Run是自动运行程序最常用的注册键,位置在:HKEY_CURRENT_USER/Software/Microsoft/Windows/CurrentVersion/Run,和HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/Run。HKEY_CURRENT_USER下面的Run键紧接HKEY_LOCAL_MACHINE下面的Run键运行,但两者都在处理“启动”文件夹之前。

下面使用的是第十方法,在Run下注册键,在Run下写入和删除键值
1.如想在开机自动行C盘下的"测试.txt",可在注册表中Run位置写入键值
[c-sharp] view plaincopyprint?DWORD dwDisposition; 
    HKEY hKey; 
    LONG result = RegCreateKeyEx( 
    HKEY_LOCAL_MACHINE, "SOFTWARE//Microsoft//Windows//CurrentVersion//Run", 
    0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, 
    NULL, &hKey, &dwDisposition); 
    if(result != ERROR_SUCCESS) 
    { 
        RegCloseKey(hKey); 
    } 
    char *path="c://测试.txt"; 
    char *key="test"; 
    result = RegSetValueEx(hKey, key, NULL, REG_SZ, (const unsigned char *)path, strlen(path)+1); 
    if(result != ERROR_SUCCESS) 
    { 
        RegCloseKey(hKey); 
    } 
    RegCloseKey(hKey); 
DWORD dwDisposition;
    HKEY hKey;
    LONG result = RegCreateKeyEx(
    HKEY_LOCAL_MACHINE, "SOFTWARE//Microsoft//Windows//CurrentVersion//Run",
    0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS,
    NULL, &hKey, &dwDisposition);
    if(result != ERROR_SUCCESS)
    {
  RegCloseKey(hKey);
    }
    char *path="c://测试.txt";
    char *key="test";
    result = RegSetValueEx(hKey, key, NULL, REG_SZ, (const unsigned char *)path, strlen(path)+1);
    if(result != ERROR_SUCCESS)
    {
  RegCloseKey(hKey);
    }
    RegCloseKey(hKey);
2.在注册表中Run位置删除键值
[c-sharp] view plaincopyprint?HKEY hkResult; 
HKEY hKey=NULL; 
TCHAR lpFilename[MAX_PATH]; 
int a=RegOpenKeyEx(HKEY_LOCAL_MACHINE,"Software//Microsoft//Windows//CurrentVersion//Run",0,KEY_ENUMERATE_SUB_KEYS|KEY_QUERY_VALUE|KEY_SET_VALUE,&hKey); 
if(a==ERROR_SUCCESS) 

    int g=RegDeleteValue(hKey,"连接助手");//删除一个键值项,切不可用其他函数  
//如RegDeleteKey或RegDeleteTree 及SHDeleteKey 函数  
    RegCloseKey(hKey); //删除后释放  
    if(g!=ERROR_SUCCESS) //执行失败获取错误信息  
    { 
       TCHAR* buffer; 
       ::FormatMessage( 
       FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, 
       NULL, 
       g, 
       0, 
      ( LPTSTR )&buffer, 
      0, 
      NULL ); 
      ::MessageBox( NULL, buffer, NULL, 0 );//输出错误信息  
      LocalFree( buffer ); 
    } 
    else 
    { 
      MessageBox(NULL,TEXT("成功关闭"),TEXT("警告!"),MB_OK); 
    } 
}   
else 

   MessageBox(NULL,TEXT("无法解除自启,尝试关闭杀毒软件以降低注册表操作权限"), 
   TEXT("警告!"),MB_OK); 
   RegCloseKey(hKey); 

 

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭