win7/8 关闭非正常关机的自动修复功能

win7/8 关闭非正常关机的自动修复功能
1、桌面右键新建一个文档文本,双击打开文件新建文本文档,复制以下命令到文本里面!
bcdedit /set {current} bootstatuspolicy ignoreallfailures
bcdedit /set {current} recoveryenabled No

2、在界面的左上角点击“文件”“另存为”,打开保存界面。在“保存格式”一行中选择“所有文件”;再把“文件名称”改为“XXX.bat”的格式,保存为一个可运行的bat文件。
3、然后桌面就出现了一个bat文件,只要双击文件就可以运行(或右键点击管理员运行),系统窗口会一闪而过,接着可以删除该bat文件,电脑以后就不会出现修复模式了。

如果要重新启用, 可以用以下命令:
bcdedit /set {current} bootstatuspolicy displayallfailures
bcdedit /set {current} recoveryenabled off

 

//启用修复功能
char szCurrentPath[MAX_PATH] = { 0 };
GetModuleFileName(NULL, szCurrentPath,MAX_PATH);
char *pFindSplitFlag = strrchr(szCurrentPath, '\\');
if (pFindSplitFlag == NULL)
{
	pFindSplitFlag = strrchr(szCurrentPath, '/');
}
if (pFindSplitFlag != NULL)
{
	*pFindSplitFlag = '\0';
}
char szCommandPath[MAX_PATH] = { 0 };
sprintf_s(szCommandPath, "%s\\%s", szCurrentPath, "StartRepairSystem.bat");
ShellExecute(0, "runas", szCommandPath,"", "", SW_SHOW);
//停用修复功能
char szCurrentPath[MAX_PATH] = { 0 };
GetModuleFileName(NULL, szCurrentPath, MAX_PATH);
char *pFindSplitFlag = strrchr(szCurrentPath, '\\');
if (pFindSplitFlag == NULL)
{
	pFindSplitFlag = strrchr(szCurrentPath, '/');
}
if (pFindSplitFlag != NULL)
{
	*pFindSplitFlag = '\0';
}
char szCommandPath[MAX_PATH] = { 0 };
sprintf_s(szCommandPath, "%s\\%s", szCurrentPath, "StopRepairSystem.bat");
ShellExecute(0, "runas", szCommandPath,"", "", SW_SHOW);
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
您好!对于在C#中实现注入任意DLL的需求,可以使用以下步骤来实现: 1. 首先,您需要创建一个C#的类库项目,用于编写注入代码。请确保项目的目标框架是.NET Framework,并且选择适当的目标CPU架构。 2. 在项目中添加对System.Process类的引用,以便我们可以获取目标程的句柄。 3. 使用Process类来获取目标程的句柄。您可以使用程名称或程ID来获取句柄。例如,以下代码获取名为"targetProcess.exe"的程句柄: ```csharp Process targetProcess = Process.GetProcessesByName("targetProcess")?.FirstOrDefault(); IntPtr targetProcessHandle = targetProcess?.Handle; ``` 4. 使用OpenProcess函数打开目标程的句柄。参数dwDesiredAccess设置为PROCESS_ALL_ACCESS以获取完全访问权限。 ```csharp [DllImport("kernel32.dll")] public static extern IntPtr OpenProcess(uint dwDesiredAccess, bool bInheritHandle, int dwProcessId); const uint PROCESS_ALL_ACCESS = 0x1F0FFF; // 具有完全访问权限 IntPtr targetProcessHandle = OpenProcess(PROCESS_ALL_ACCESS, false, targetProcessId); ``` 5. 使用VirtualAllocEx函数在目标程中分配内存。参数lpAddress设置为0以让系统自动选择地址。参数dwSize设置为你要注入DLL的大小。 ```csharp [DllImport("kernel32.dll")] public static extern IntPtr VirtualAllocEx(IntPtr hProcess, IntPtr lpAddress, uint dwSize, uint flAllocationType, uint flProtect); IntPtr dllMemoryAddress = VirtualAllocEx(targetProcessHandle, IntPtr.Zero, (uint)dllBytes.Length, 0x1000, 0x40); ``` 6. 使用WriteProcessMemory函数将DLL的字节写入目标程的内存中。 ```csharp [DllImport("kernel32.dll")] public static extern bool WriteProcessMemory(IntPtr hProcess, IntPtr lpBaseAddress, byte[] lpBuffer, uint nSize, out int lpNumberOfBytesWritten); bool success = WriteProcessMemory(targetProcessHandle, dllMemoryAddress, dllBytes, (uint)dllBytes.Length, out int bytesWritten); ``` 7. 使用CreateRemoteThread函数在目标程中创建一个远程线程,以加载注入的DLL。 ```csharp [DllImport("kernel32.dll")] public static extern IntPtr CreateRemoteThread(IntPtr hProcess, IntPtr lpThreadAttributes, uint dwStackSize, IntPtr lpStartAddress, IntPtr lpParameter, uint dwCreationFlags, IntPtr lpThreadId); IntPtr loadLibraryAddress = GetProcAddress(GetModuleHandle("kernel32.dll"), "LoadLibraryA"); IntPtr threadHandle = CreateRemoteThread(targetProcessHandle, IntPtr.Zero, 0, loadLibraryAddress, dllMemoryAddress, 0, IntPtr.Zero); ``` 请注意,上述代码只是一个示例,实际在实现过程中可能需要根据具体情况行修改和调整。此外,为了支持不同的操作系统和CPU架构,您可能需要根据编译条件行相应的处理。 希望以上信息对您有所帮助!如有任何疑问,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

byxdaz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值