検索
ホームページバックエンド開発C#.Net チュートリアル64 ビット レジストリにアクセスするための C# 32 ビット プログラムのサンプル コード


前回の記事で「64 ビット プラットフォームでのレジストリの読み取りと書き込みにおける 32 ビット プログラムと 64 ビット プログラムの違い」について説明しました。次に、前回の記事で残った質問に答えます。ビット プログラムは 64 ビット システム レジストリ (つまり、64 ビット プログラムがアクセスするレジストリの場所) にどのようにアクセスしますか。

私たちはすでに知っています:

①: ネイティブ モード 64 ビット プログラムはネイティブ モードで実行され、次のレジストリ サブキーに格納されているキーと値にアクセスします: HKEY_LOCAL_MACHINESoftware

②: 32 ビットプログラムは WOW64 モードで実行され、アクセス キーと値は次のレジストリ サブキーに保存されます: HKEY_LOCAL_MACHINESoftwareWOW6432nod

したがって、64 ビットのレジストリ情報にアクセスする 32 ビット プログラムを実装するには、次の概念も知っておく必要があります。 1: ファイル システムのリダイレクト。 2: レジストリのリダイレクト (方向)。 3: レジストリの反映。

①:ファイルシステムステアリング

32ビットプロセスは64ビットDLLをロードできず、64ビットプロセスは32ビットDLLをロードできません。 Windows システム ディレクトリには、インストールされているすべてのアプリケーションとその DLL ファイルが含まれています。

64 ビット アプリケーション用のディレクトリと 32 ビット アプリケーション用のディレクトリに分割する必要があります。そうしないと、32 ビットと 64 ビットの DLL ファイルを区別できなくなります。 64 ビット アプリケーションの場合、そのファイルは通常、%windir%system32 および %programfiles% に配置されます (例: c:program files)。 32 ビット アプリケーションの場合、ファイルは通常、%windir%syswow64 および

C:program ファイル (x86) の下にあります。 32 ビット プログラムを使用して %windir%system32 にアクセスすると、ハード コーディングを使用するか他の方法を使用するかに関係なく、システムは自動的に %windir%syswow64 にリダイレクトします。このリダイレクトは、すべての 32 ビット アプリケーションでデフォルトでオンになります。しかし、この種のリダイレクトは必ずしも必要というわけではありません。次に、C# で関連する API を呼び出して、この種のステアリングを閉じたり開いたりすることができます。よく使用される関数は 3 つあります:

Wow64DisableWow64FsRedirection (システム リダイレクトをオフにする)、

Wow64RevertWow64FsRedirection (システム リダイレクトをオンにする)、

4EnableWow64FsRedirection (システムのリダイレクトを有効にします)。

wow6444enablewow64fsredirectionはネストされたモードで使用すると信頼できないため、上記のwow64revertwow64fsredirectionは通常、ファイルシステムのリダイレクトを開くために使用されます。したがって、ネストした形式で使用すると、通常は信頼性が低くなります。 C# では、DllImport を使用してこれら 2 つの関数を直接呼び出すことができます。

②:レジストリリダイレクト(リダイレクト)

32ビットと64ビットのCOM登録とプログラムの共存状態をサポートするために、WOW64サブシステムは32ビットプログラムで使用されるレジストリの別のビューを提供します。 WOW64 サブシステムのレジストリを使用する

ビットレベルのレジストリ呼び出しのインターセプトをリダイレクトします。レジストリ リダイレクトにより、レジストリ呼び出しがレジストリ内の正しいブランチに確実に送信されるようになります。

新しいプログラムをインストールするとき、または Windows x64 バージョンのコンピューターでプログラムを実行するとき、HKEY_LOCAL_MACHINESoftware レジストリ サブキーにアクセスするために 64 ビット プログラムによって行われるレジストリ呼び出し

リダイレクトされません。 WOW64 は、32 ビット プログラムによって HKEY_LOCAL_MACHINESoftware に対して行われたレジストリ呼び出しをインターセプトし、それらを

HKEY_LOCAL_MACHINESoftwareWOW6432node サブキーにリダイレクトします。 WOW64 は 32 ビット プログラム呼び出しのみをリダイレクトすることで、プログラムが常に対応するレジストリ サブキーに書き込むようにします。

レジストリのリダイレクトにはプログラムコードの変更は必要なく、このプロセスはユーザーに対して透過的です。
③:レジストリリフレクション

リフレクションにより、同じレジストリの2つの物理コピーの存在が可能になり、ネイティブとWOW64の同時操作をサポートします

64ビットレジストリを開きます セクションはいつでも利用できますレジストリ リフレクションは、32 ビットに対応するリアルタイムの方法を提供します。

これらを簡単に理解した後、具体的な 実装手順について説明します。

664ビット(ファイルシステム)操作リダイレクトをオフにしますcorpution操作キー値にハンドルを取得

in in in in on in 特定項目のレジストリ反映 ——特定項目のレジストリ反映 ) 特定項目のレジストリ反映 )

名前空間の紹介: 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 関数の 3 つのパラメーターは次を表します: 主キー名 (HKEY_LOCAL_MACHINE など)、サブキー名、キー名はキーの値 (64 ビットのキーの値) を返します。上記の方法により、32 ビット プログラムを使用して 64 ビット システム レジストリ (つまり、64 ビット プログラムがアクセスするレジストリの場所) にアクセスすることが完全に可能になります。

以上が64 ビット レジストリにアクセスするための C# 32 ビット プログラムのサンプル コードの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
c#.netはあなたにぴったりですか?その適用性の評価c#.netはあなたにぴったりですか?その適用性の評価Apr 13, 2025 am 12:03 AM

c#.netissuitableforenterprise-levelApplicationsとsystemduetoitsSystemdutyping、richlibraries、androbustperformance.

.NET内のC#コード:プログラミングプロセスの調査.NET内のC#コード:プログラミングプロセスの調査Apr 12, 2025 am 12:02 AM

.NETでのC#のプログラミングプロセスには、次の手順が含まれます。1)C#コードの作成、2)中間言語(IL)にコンパイルし、3).NETランタイム(CLR)によって実行される。 .NETのC#の利点は、デスクトップアプリケーションからWebサービスまでのさまざまな開発シナリオに適した、最新の構文、強力なタイプシステム、および.NETフレームワークとの緊密な統合です。

C#.NET:コアの概念とプログラミングの基礎を探るC#.NET:コアの概念とプログラミングの基礎を探るApr 10, 2025 am 09:32 AM

C#は、Microsoftによって開発された最新のオブジェクト指向プログラミング言語であり、.NETフレームワークの一部として開発されています。 1.C#は、カプセル化、継承、多型を含むオブジェクト指向プログラミング(OOP)をサポートしています。 2。C#の非同期プログラミングは非同期を通じて実装され、適用応答性を向上させるためにキーワードを待ちます。 3. LINQを使用してデータ収集を簡潔に処理します。 4.一般的なエラーには、null参照の例外と、範囲外の例外インデックスが含まれます。デバッグスキルには、デバッガーと例外処理の使用が含まれます。 5.パフォーマンスの最適化には、StringBuilderの使用と、不必要な梱包とボクシングの回避が含まれます。

テストC#.NETアプリケーション:ユニット、統合、およびエンドツーエンドテストテストC#.NETアプリケーション:ユニット、統合、およびエンドツーエンドテストApr 09, 2025 am 12:04 AM

C#.NETアプリケーションのテスト戦略には、ユニットテスト、統合テスト、エンドツーエンドテストが含まれます。 1.単位テストにより、コードの最小ユニットがMSTEST、ヌニット、またはXUNITフレームワークを使用して独立して動作することを保証します。 2。統合テストでは、一般的に使用されるシミュレートされたデータと外部サービスを組み合わせた複数のユニットの機能を検証します。 3.エンドツーエンドのテストでは、ユーザーの完全な操作プロセスをシミュレートし、通常、セレンは自動テストに使用されます。

高度なC#.NETチュートリアル:次のシニア開発者インタビューをエース高度なC#.NETチュートリアル:次のシニア開発者インタビューをエースApr 08, 2025 am 12:06 AM

C#シニア開発者とのインタビューでは、非同期プログラミング、LINQ、.NETフレームワークの内部作業原則などのコア知識をマスターする必要があります。 1.非同期プログラミングは、非同期を通じて操作を簡素化し、アプリケーションの応答性を向上させるのを待ちます。 2.LinqはSQLスタイルでデータを操作し、パフォーマンスに注意を払います。 3.ネットフレームワークのCLRはメモリを管理し、ガベージコレクションに注意して使用する必要があります。

c#.netインタビューの質問と回答:専門知識を高めるc#.netインタビューの質問と回答:専門知識を高めるApr 07, 2025 am 12:01 AM

C#.NETインタビューの質問と回答には、基本的な知識、コアの概念、高度な使用が含まれます。 1)基本知識:C#は、Microsoftが開発したオブジェクト指向言語であり、主に.NETフレームワークで使用されています。 2)コアの概念:委任とイベントは動的な結合方法を可能にし、LINQは強力なクエリ関数を提供します。 3)高度な使用:非同期プログラミングは応答性を向上させ、式ツリーは動的コード構造に使用されます。

C#.NETを使用したマイクロサービスの構築:建築家向けの実用的なガイドC#.NETを使用したマイクロサービスの構築:建築家向けの実用的なガイドApr 06, 2025 am 12:08 AM

C#.NETは、その強力なエコシステムと豊富なサポートのため、マイクロサービスを構築するために人気のある選択肢です。 1)asp.netcoreを使用してRestfulapiを作成して、順序の作成とクエリを処理します。 2)GRPCを使用して、マイクロサービス間の効率的な通信を実現し、注文サービスを定義および実装します。 3)Dockerコンテナ化されたマイクロサービスを介して展開と管理を簡素化します。

C#.NETセキュリティベストプラクティス:一般的な脆弱性の防止C#.NETセキュリティベストプラクティス:一般的な脆弱性の防止Apr 05, 2025 am 12:01 AM

C#および.NETのセキュリティベストプラクティスには、入力検証、出力エンコード、例外処理、認証と承認が含まれます。 1)正規表現または組み込みのメソッドを使用して入力を検証して、悪意のあるデータがシステムに入るのを防ぎます。 2)XSS攻撃を防ぐための出力エンコード、httputility.htmlencodeメソッドを使用します。 3)例外処理により、情報の漏れが回避され、エラーが記録されますが、詳細情報はユーザーに返されません。 4)ASP.Netidentityおよび請求に基づく許可を使用して、不正アクセスから申請を保護します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール