App.config からの接続文字列へのアクセス: NullReferenceExceptions の回避
App.config ファイルから接続文字列を取得するには、NullReferenceException
エラーを防ぐために慎重な処理が必要です。 次のコード例を考えてみましょう:
<code class="language-csharp">var connection = ConnectionFactory.GetConnection( ConfigurationManager.ConnectionStrings["Test"] .ConnectionString, DataBaseProvider);</code>
このコード スニペットは、次のように標準 App.config ファイルで使用される場合:
<code class="language-xml"><?xml version="1.0" encoding="utf-8" ?> <configuration> <connectionStrings> <add connectionString="Data Source=.;Initial Catalog=OmidPayamak;Integrated Security=True" name="Test" providerName="System.Data.SqlClient" /> </connectionStrings> </configuration></code>
は、接続文字列「Test」が見つからない場合に NullReferenceException
をスローできます。 問題は、null をチェックせずに .ConnectionString
に直接アクセスすることにあります。
堅牢なソリューションには、プロパティにアクセスする前に接続文字列の存在を確認することが含まれます。
<code class="language-csharp">var connectionString = ConfigurationManager.ConnectionStrings["Test"]; if (connectionString != null) { var connection = ConnectionFactory.GetConnection(connectionString.ConnectionString, DataBaseProvider); // ... use the connection ... } else { // Handle the case where the connection string is not found. // Log an error, throw an exception, or use a default connection. }</code>
代わりに、NULL 条件演算子 (?.) を使用したより簡潔なアプローチを使用することもできます。
<code class="language-csharp">var connection = ConnectionFactory.GetConnection( ConfigurationManager.ConnectionStrings["Test"]?.ConnectionString, DataBaseProvider);</code>
これは、「Test」が欠落している場合に connection
を null に設定することで、null の場合を適切に処理します。 このシナリオでは、必ず適切なエラー処理を追加してください。
最後に、プロジェクトに System.Configuration.dll
への参照を忘れずに含めてください。このアセンブリは、構成設定にアクセスするために必要なクラスを提供します。 この参照がないとコンパイルは失敗します。
以上がApp.config から接続文字列を取得するときに「オブジェクト参照がオブジェクトのインスタンスに設定されていません」を回避するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。