64비트 레지스트리에 액세스하기 위한 C# 32비트 프로그램용 샘플 코드
지난 기사에서 "64비트 플랫폼에서 레지스트리를 읽고 쓰는 데 있어 32비트 프로그램과 64비트 프로그램의 차이점"에 대해 이미 설명했으므로 다음으로 넘어갑니다. 다음 답변 이전 기사에서 남은 질문: 32비트 프로그램이 64비트 시스템 레지스트리(예: 64비트 프로그램이 액세스하는 레지스트리 위치)에 어떻게 액세스합니까?
우리는 이미 알고 있다:
①: 기본 모드 64비트 프로그램은 기본 모드에서 실행되며, 액세스 키와 저장소는 아래에 등록됩니다. 테이블 하위 키의 값: HKEY_LOCAL_MACHINESoftware
②: 32비트 프로그램은 WOW64 모드에서 실행되며 액세스 키와 값은 다음 레지스트리 하위 키에 저장됩니다: HKEY_LOCAL_MACHINESoftwareWOW6432nod
그런 다음 64비트 레지스트리 정보에 액세스하기 위한 32비트 프로그램을 구현하려면 다음 개념도 알아야 합니다. 1: 파일 시스템 조정. 2: 레지스트리 리디렉션(방향). 3: 레지스트리 반영.
①: 파일 시스템 리디렉션
32비트 프로세스는 64비트 DLL을 로드할 수 없으며 64비트도 로드할 수 없습니다. -bit 프로세스 32비트 DLL을 로드합니다. Windows 시스템 디렉터리에는 설치된 모든 응용 프로그램과 해당 Dll 파일이 포함되어 있습니다.
이는 64비트 응용 프로그램용 디렉터리와 64비트 응용 프로그램용 디렉터리로 구분되어야 합니다. . 32비트 응용프로그램용 디렉토리입니다. 그렇지 않으면 32비트와 64비트 Dll 파일을 구별할 수 없습니다. 64비트 응용 프로그램의 경우 해당 파일은 일반적으로 %windir%system32 및 %programfiles%(예: c:program 파일)에 배치됩니다. 32비트 애플리케이션의 경우 파일은 일반적으로 %windir%syswow64 및
C:program files(x86) 아래에 있습니다. 32비트 프로그램을 사용하여 %windir%system32에 액세스하는 경우 하드 코딩을 사용하든 다른 방법을 사용하든 시스템은 자동으로 %windir%syswow64로 리디렉션됩니다. 이 리디렉션은 모든 32비트 애플리케이션에 대해 기본적으로 켜져 있습니다. 그러나 이러한 방향 전환이 항상 필요한 것은 아닙니다. 그런 다음 C#에서 관련 API를 호출하여 이러한 종류의 조정을 닫거나 열 수 있습니다. 일반적으로 사용되는 기능은 세 가지입니다:
Wow64DisableWow64FsRedirection(시스템 리디렉션 끄기),
Wow64RevertWow64FsRedirection(시스템 리디렉션 켜기),
Wow64EnableWow64FsRedirection(시스템 리디렉션 켜기).
하지만 Wow64EnableWow64FsRedirection은 중첩 모드에서 사용할 때 안정적이지 않으므로 위의 Wow64RevertWow64FsRedirection은 일반적으로 파일 시스템 리디렉션
함수를 여는 데 사용됩니다. C#에서는 DllImport를 사용하여 이 두 함수를 직접 호출할 수 있습니다.
②: 레지스트리 리디렉션(방향)
32비트 및 64비트 COM 등록을 지원합니다. 프로그램 공존 상태에 따라 WOW64 하위 시스템은 32비트 프로그램에서 사용하는 레지스트리에 대한 또 다른 보기를 제공합니다. WOW64 하위 시스템의
레지스트리를 사용하여 비트 수준 레지스트리 호출을 가로채도록 리디렉션합니다. 또한 레지스트리 리디렉션은 레지스트리 호출이 레지스트리의 올바른 분기로 전달되도록 보장합니다.
Windows x64 버전의 컴퓨터에서 새 프로그램을 설치하거나 프로그램을 실행할 때 64비트 프로그램의 레지스트리 호출이 HKEY_LOCAL_MACHINESoftware 레지스트리 하위 키에 액세스합니다.
리디렉션이 없습니다. WOW64는 32비트 프로그램에서 HKEY_LOCAL_MACHINESoftware에 대한 레지스트리 호출을 가로채서 HKEY_LOCAL_MACHINESoftwareWOW6432node 하위 키로 리디렉션합니다. 32비트 프로그램 호출만 리디렉션함으로써 WOW64는 프로그램이 항상 해당 레지스트리 하위 키에 쓰도록 보장합니다.
레지스트리 리디렉션에는 프로그램 코드 수정이 필요하지 않으며 프로세스가 사용자에게 투명합니다.
3: 레지스트리 반영
반사는 이 파일의 동시 실행을 지원하기 위해 두 개의 동일한 레지스트리를 만듭니다. 머신의 물리적 복사본과 WOW64 작업을 수행하는 경우
는 항상 레지스트리의 64비트 섹션을 열고 레지스트리 반영은 32비트를 수용하는 실시간 방법을 제공합니다.
이를 간략하게 이해한 후 구체적인 구현 단계에 대해 이야기해 보겠습니다.
작업 핸들 가져오기 키 값
> 🎜>
액세스 키 값레지스트리 리디렉션 켜기(켜기) 특정 항목에 대한 레지스트리 반영) )
64비트(파일 시스템) 작동 켜기
【참고: 프로그램에서 DllImport를 사용하므로 네임스페이스를 도입해야 합니다. System.Runtime.InteropServices】
1 using System;
2 using System.Collections.Generic;
3 using System.Linq;
4 using System.Text;
5 using Microsoft.Win32;
6 using System.Runtime.InteropServices;
7
8 namespace OperateRegistrationTable
9 {
10 class Programe
11 {
12 static void Main(string[] args)
13 {
14 string myParentKeyName = "HKEY_LOCAL_MACHINE";
15 string mySubKeyName = @"SOFTWARE\EricSun\MyTestKey";
16 string myKeyName = "MyKeyName";
17
18 string value = string.Empty;
19 value = Utility.Get64BitRegistryKey(myParentKeyName, mySubKeyName, myKeyName);
20 Console.WriteLine("The Value is: {0}", value);
21 }
22 }
23
24 public class Utility
25 {
26 #region 32位程序读写64注册表
27
28 static UIntPtr HKEY_CLASSES_ROOT = (UIntPtr)0x80000000;
29 static UIntPtr HKEY_CURRENT_USER = (UIntPtr)0x80000001;
30 static UIntPtr HKEY_LOCAL_MACHINE = (UIntPtr)0x80000002;
31 static UIntPtr HKEY_USERS = (UIntPtr)0x80000003;
32 static UIntPtr HKEY_CURRENT_CONFIG = (UIntPtr)0x80000005;
33
34 // 关闭64位(文件系统)的操作转向
35 [DllImport("Kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
36 public static extern bool Wow64DisableWow64FsRedirection(ref IntPtr ptr);
37 // 开启64位(文件系统)的操作转向
38 [DllImport("Kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
39 public static extern bool Wow64RevertWow64FsRedirection(IntPtr ptr);
40
41 // 获取操作Key值句柄
42 [DllImport("Advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
43 public static extern uint RegOpenKeyEx(UIntPtr hKey, string lpSubKey, uint ulOptions,
int samDesired, out IntPtr phkResult);
44 //关闭注册表转向(禁用特定项的注册表反射)
45 [DllImport("Advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
46 public static extern long RegDisableReflectionKey(IntPtr hKey);
47 //使能注册表转向(开启特定项的注册表反射)
48 [DllImport("Advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
49 public static extern long RegEnableReflectionKey(IntPtr hKey);
50 //获取Key值(即:Key值句柄所标志的Key对象的值)
51 [DllImport("Advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
52 private static extern int RegQueryValueEx(IntPtr hKey, string lpValueName, int lpReserved,
53 out uint lpType, System.Text.StringBuilder lpData,
54 ref uint lpcbData);
55
56 private static UIntPtr TransferKeyName(string keyName)
57 {
58 switch (keyName)
59 {
60 case "HKEY_CLASSES_ROOT":
61 return HKEY_CLASSES_ROOT;
62 case "HKEY_CURRENT_USER":
63 return HKEY_CURRENT_USER;
64 case "HKEY_LOCAL_MACHINE":
65 return HKEY_LOCAL_MACHINE;
66 case "HKEY_USERS":
67 return HKEY_USERS;
68 case "HKEY_CURRENT_CONFIG":
69 return HKEY_CURRENT_CONFIG;
70 }
71
72 return HKEY_CLASSES_ROOT;
73 }
74
75 public static string Get64BitRegistryKey(string parentKeyName, string subKeyName, string keyName)
76 {
77 int KEY_QUERY_VALUE = (0x0001);
78 int KEY_WOW64_64KEY = (0x0100);
79 int KEY_ALL_WOW64 = (KEY_QUERY_VALUE | KEY_WOW64_64KEY);
80
81 try
82 {
83 //将Windows注册表主键名转化成为不带正负号的整形句柄(与平台是32或者64位有关)
84 UIntPtr hKey = TransferKeyName(parentKeyName);
85
86 //声明将要获取Key值的句柄
87 IntPtr pHKey = IntPtr.Zero;
88
89 //记录读取到的Key值
90 StringBuilder result = new StringBuilder("".PadLeft(1024));
91 uint resultSize = 1024;
92 uint lpType = 0;
93
94 //关闭文件系统转向
95 IntPtr oldWOW64State = new IntPtr();
96 if (Wow64DisableWow64FsRedirection(ref oldWOW64State))
97 {
98 //获得操作Key值的句柄
99 RegOpenKeyEx(hKey, subKeyName, 0, KEY_ALL_WOW64, out pHKey);
100
101 //关闭注册表转向(禁止特定项的注册表反射)
102 RegDisableReflectionKey(pHKey);
103
104 //获取访问的Key值
105 RegQueryValueEx(pHKey, keyName, 0, out lpType, result, ref resultSize);
106
107 //打开注册表转向(开启特定项的注册表反射)
108 RegEnableReflectionKey(pHKey);
109 }
110
111 //打开文件系统转向
112 Wow64RevertWow64FsRedirection(oldWOW64State);
113
114 //返回Key值
115 return result.ToString().Trim();
116 }
117 catch (Exception ex)
118 {
119 return null;
120 }
121 }
122
123 #endregion
124 }
125 }
Get64BitRegistryKey 함수의 세 매개변수는 각각 기본 키 이름(예: HKEY_LOCAL_MACHINE 등), 하위 키 이름, 키 이름을 나타냅니다. , 반환된 값은 키 값(64비트 시스템 레지스트리의 키 값)입니다. 위의 방법을 통해 32비트 프로그램을 사용하여 64비트 시스템 레지스트리에 액세스하는 것이 완전히 가능합니다(예: : 64비트 프로그램에서 액세스하는 레지스트리 위치입니다.
위 내용은 64비트 레지스트리에 액세스하기 위한 C# 32비트 프로그램용 샘플 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











C#을 사용한 Active Directory 가이드. 여기에서는 소개와 구문 및 예제와 함께 C#에서 Active Directory가 작동하는 방식에 대해 설명합니다.

C#의 난수 생성기 가이드입니다. 여기서는 난수 생성기의 작동 방식, 의사 난수 및 보안 숫자의 개념에 대해 설명합니다.

C# 데이터 그리드 뷰 가이드. 여기서는 SQL 데이터베이스 또는 Excel 파일에서 데이터 그리드 보기를 로드하고 내보내는 방법에 대한 예를 설명합니다.

멀티 스레딩과 비동기식의 차이점은 멀티 스레딩이 동시에 여러 스레드를 실행하는 반면, 현재 스레드를 차단하지 않고 비동기식으로 작업을 수행한다는 것입니다. 멀티 스레딩은 컴퓨팅 집약적 인 작업에 사용되며 비동기식은 사용자 상호 작용에 사용됩니다. 멀티 스레딩의 장점은 컴퓨팅 성능을 향상시키는 것이지만 비동기의 장점은 UI 스레드를 차단하지 않는 것입니다. 멀티 스레딩 또는 비동기식을 선택하는 것은 작업의 특성에 따라 다릅니다. 계산 집약적 작업은 멀티 스레딩을 사용하고 외부 리소스와 상호 작용하고 UI 응답 성을 비동기식으로 유지 해야하는 작업을 사용합니다.
