| ページ一覧 | ブログ | twitter |  書式 | 書式(表) |

MyMemoWiki

「.NET Core」の版間の差分

提供: MyMemoWiki
ナビゲーションに移動 検索に移動
99行目: 99行目:
 
===サービスの有効期間===
 
===サービスの有効期間===
 
----
 
----
 +
====サービス登録メソッド====
 +
----
 +
{|class="wikitable"
 +
!メソッド
 +
!例
 +
!自動object破棄
 +
!複数実装
 +
!引数を渡す
 +
|-
 +
|
 +
|
 +
|
 +
|
 +
|
 +
|-
 +
|
 +
|
 +
|
 +
|
 +
|
 +
|-
 +
|
 +
|
 +
|
 +
|
 +
|
 +
|-
 +
|
 +
|
 +
|
 +
|
 +
|
 +
|-
 +
|
 +
|
 +
|
 +
|
 +
|
 +
|-
 +
|
 +
|
 +
|
 +
|
 +
|
 +
|-
 +
|}
 +
 +
 +
  
 
====Cannot consume scoped service from singleton====
 
====Cannot consume scoped service from singleton====

2021年8月10日 (火) 01:17時点における版

| C Sharp | ASP.NET Core | .NET Core Console | Xamarin |

.NET Core

.NET Core


  • 最新の .NET 実装です。オープン ソースで、複数の OS 向けに利用できます。
  • .NET Core により、クロスプラットフォーム コンソール アプリケーション、ASP.NET Core Web アプリケーション、およびクラウド サービスをビルドできます。

.NET Standard


  • すべての .NET 実装が実装する必要のある基本 API のセットです。
  • この API を基本クラス ライブラリ (BCL) と呼びます。
  • .NET Standard をターゲットにすることで、どの .NET 実装やどの OS で実行されても、すべての .NET アプリケーションが共有できるライブラリをビルドできます。

.NET API ブラウザ


.NET ソースブラウザ


インストール

ダウンロード


Mac


ASP.NET Core参照

アンインストールツール


CLIコマンド

SDKコマンド


コマンド 内容
dotnet --info .NET Core 情報の表示

パッケージの追加


  1. dotnet add package Microsoft.Extensions.Configuration.Binder --version 5.0.0
  2. dotnet add package Microsoft.Extensions.Configuration.CommandLine --version 5.0.0
  3. dotnet add package Microsoft.Extensions.Configuration.Json --version 5.0.0
  4. dotnet add package Microsoft.Extensions.DependencyInjection --version 5.0.1
  5. dotnet add package Microsoft.Extensions.Hosting --version 5.0.0
  6. dotnet add package Microsoft.Extensions.Options --version 5.0.0
  7. dotnet add package MongoDB.Driver --version 2.12.4
  8. dotnet add package Newtonsoft.Json.Bson --version 1.0.2
  9. dotnet add package Newtonsoft.Json --version 13.0.1
  10. dotnet add package Microsoft.Extensions.Logging.Log4Net.AspNetCore --version 5.0.3

.gitignoreの作成


  1. $ dotnet new gitignore

プロジェクトレンプレート

dotnet new


  1. $ dotnet new web

=ソリューション


  • カレントディレクトリにソリューションファイルを作成
  1. $ dotnet new sln -o .
  • カレントディレクトリのソリューションにプロジェクトを追加
  1. $ dotnet sln add {プロジェクトファイルパス}
  • ビルド
  1. $ dotnet clean
  2. $ dotnet build

NET での依存関係の挿入


サービスの有効期間


サービス登録メソッド


メソッド 自動object破棄 複数実装 引数を渡す



Cannot consume scoped service from singleton

  • 既定では、開発環境で、より長い有効期間を持つ別のサービスからサービスを解決すると、例外がスローされます。
  • スコープの検証
  • シングルトンからスコープ付きサービスを解決 しない でください。また、たとえば一時的なサービスにより、間接的に解決しないようにご注意ください

exe を出力

デプロイ方法の名称 略称 実行方法
Framework-dependent deployments FDD コマンドで dotnet hoge.dll として実行する
Self-contained deployments SCD 実行ファイルを直接実行する

日本語コーデック

  • NuGet で System.Text.Encoding.CodePages を追加
  • 初期化時に 以下を実行
    • System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);

Console

設定ファイル

  1. dotnet add package Microsoft.Extensions.Configuration.Json --version 5.0.0
  1. using System;
  2. using System.IO;
  3. using Microsoft.Extensions.Configuration;
  4.  
  5. namespace docweb_bat
  6. {
  7. public class Program
  8. {
  9. static void Main(string[] args)
  10. {
  11. // export DECWEB_ENV=Development
  12. var environmentName = Environment.GetEnvironmentVariable("DOCWEB_ENV");
  13. Console.WriteLine($"Environment:{environmentName}");
  14. IConfiguration configuration = new ConfigurationBuilder()
  15. .SetBasePath(Directory.GetCurrentDirectory())
  16. .AddJsonFile("appsettings.json", true, true)
  17. .AddJsonFile($"appsettings.{environmentName}.json", true, true)
  18. .Build();
  19. IConfigurationSection section = configuration.GetSection("DocumentWebDatabaseSettings");
  20. string str = section["DocumentWebCollectionName"];
  21. Console.WriteLine(str);
  22. }
  23. }
  24. }