.Net 6.0 のWindowsフォームアプリと、Core WCF とを接続して通信するサンプルを作成しました。WCFの .NET 6.0(.Net Core)版が Core WCF です。
ソースコードはGitHubで公開しています。
開発ツール インストール
Core WCFは .NET 6.0以降で稼働し、.NET 6.0は VisualStudio2022以降じゃないと開発できないので、事前に VisualStudio2022のインストールが必要。
Core WCFの開発には、別途、Core WCF の VisualStudioプロジェクトテンプレートのインストールが必要。
CoreWCF.Templatesの installコマンドをコマンドプロンプトで実行することで、Core WCF の VisualStudioプロジェクトテンプレートをインストールできる。
1 2 3 |
> dotnet new --install CoreWCF.Templates |
CoreWCF.Templatesをインストールすると、VisualStudio2022の「新しいプロジェクトの作成」で「CoreWCF」プロジェクトを選べるようになる。
「CoreWCF」プロジェクトが Core WCFのサーバ側になる。
data:image/s3,"s3://crabby-images/b00ec/b00ec103ffad684caf7eb723b5cd8dd2bdea3350" alt=""
data:image/s3,"s3://crabby-images/9627f/9627f79d139fb77f71feb60ee2ddf6c954806a6d" alt=""
data:image/s3,"s3://crabby-images/c185e/c185e6feac672b7cdb9f8a73e481b485a9ba3e1b" alt=""
CoreWCF のクライアント側として、.NET 6.0 の「Windowsフォームアプリ」を作成。
※WCFのクライアントは「Windowsフォームアプリ」で作られることが多い気がする。
data:image/s3,"s3://crabby-images/9ae61/9ae6167cfa50433d43d264b0dcad1d1e168d004c" alt=""
data:image/s3,"s3://crabby-images/2add1/2add15fe93a982d1a932ca7e344a7b30c8846aca" alt=""
data:image/s3,"s3://crabby-images/a64ac/a64ac4fe8e66742aa84252be51c3189dc0b6c351" alt=""
Windowsフォームアプリから CoreWCFサーバへ接続
CoreWCFサーバ側プロジェクトをデバッグ実行すると、コンソールが立ち上がり接続先情報が表示される。
data:image/s3,"s3://crabby-images/b924b/b924b041f0fbe500fb46eca2d9e49dd78ff2f207" alt=""
CoreWCFサーバのコンソールに表示された接続先URLを、ブラウザで表示した際の画面は、.Net Frameworkで実装したWCFと変わらない。
data:image/s3,"s3://crabby-images/3bc8f/3bc8f4e49158ad13ff304699692afaf7c637f83b" alt=""
Windowsフォームプロジェクト(CoreWCFクライアント)を右クリックし、「追加 > サービス参照」を選択。
data:image/s3,"s3://crabby-images/05e32/05e32e365e37a463dc1f3eb06d72c5e2b5c29c6d" alt=""
「WCF Web Service」を選択し「次へ」をクリック。
data:image/s3,"s3://crabby-images/275f7/275f72a5c6f8e33c31f872213db4776b52530d0e" alt=""
URLに CoreWCFの single file URLを入力し「移動」をクリック。
data:image/s3,"s3://crabby-images/19aa9/19aa96baaf02181b5fe9e3b7cd619b4d65abfffa" alt=""
data:image/s3,"s3://crabby-images/b0acf/b0acf2c21e499176dcb18abc79578fa8f7853443" alt=""
サービスが検出されたことを確認し「次へ」をクリック。
data:image/s3,"s3://crabby-images/80b17/80b170cf5dc7ce8681e838edf05ef0d2878ba588" alt=""
特に変更せず「次へ」をクリック。
data:image/s3,"s3://crabby-images/ae087/ae0875b1c0efdf2cc7b34f41fa487105b46c5e44" alt=""
特に変更せず「完了」をクリック。
data:image/s3,"s3://crabby-images/b3eb8/b3eb81f5dececddbc6982a272351512e7c75d322" alt=""
「閉じる」をクリック。
data:image/s3,"s3://crabby-images/c6ec8/c6ec8747c47d7c4b636e1e0f933abe547b22530f" alt=""
Connected Servicesフォルダが追加される。
data:image/s3,"s3://crabby-images/55055/55055cfd062fbedfaa2be235a4160aeba3c5d431" alt=""
CoreWCFのサービスを呼び出す処理をクライアント側に実装
Windowsフォーム画面のボタンクリック処理に、CoreWCFのクライアントからAPIをキックする処理を追加。
1 2 3 4 5 |
var client = new ServiceReference1.ServiceClient(); var result = await client.GetDataAsync(12345); MessageBox.Show(result); |
data:image/s3,"s3://crabby-images/97155/9715528fad91e68685f1def25cff247b6badd150" alt=""
Windowsフォームアプリを起動し、画面のボタンクリックすると、CoreWCF APIを通した結果がメッセージボックスに表示される。
data:image/s3,"s3://crabby-images/96b96/96b9643fd215d34fda5c6d5e066052ca30530b41" alt=""
CoreWCFサーバ側のインターフェース変更をクライアント側へ反映する
CoreWCFへ接続した後、CoreWCFサーバ側のインターフェース定義が変更した場合、CoreWCFクライアント側のインターフェース定義は自動更新されないので、手動で更新し、CoreWCFサーバ側とクライアント側のインターフェース定義を合わせる必要があります。
CoreWCFサーバ側をデバッグ実行し、CoreWCFクライアントから接続可能な状態にした上で、下記手順を行うと同期できます。
Windowsフォームプロジェクト(CoreWCFクライアント)を右クリックし、「追加 > 接続済みサービス」を選択。
data:image/s3,"s3://crabby-images/a37d9/a37d984d3c838c2e6ad89790bbc5ef10e56da35e" alt=""
対象サービスの「編集」を選択。
data:image/s3,"s3://crabby-images/329d5/329d579caae01966285eea9d2df3385b088f2f0b" alt=""
特に変更せず「移動」をクリック。
後は初回サービス参照時と同じ。
data:image/s3,"s3://crabby-images/cdfe9/cdfe9446c6393007a87c3e9ecde6e2ef0fb8108b" alt=""
WCFと Core WCFには、ほとんど違いがないらしい。
CoreWCFは .NET Framework 4.8 上でも実装できる。
ソースコードはGitHubで公開しています。
data:image/s3,"s3://crabby-images/c2415/c2415d67dfcd93da31cc85b1d3592e9f10e13a32" alt=""
CoreWCFプロジェクトを .NET Framework 4.8 で作成した場合、Microsoft.AspNetCore Nugetパッケージもインストールされるので、 .NET Framework 4.8 ベースで開発作業は進めれらるけど、CoreWCFの実行環境は .Net Coreベースの AspNetCoreになるみたい。
data:image/s3,"s3://crabby-images/b05a6/b05a67165b39e3dcf479c967e2cce6a281c72405" alt=""
.NET Framework 4.8 で実装した CoreWCFプロジェクトを実行した場合。 .NET 6.0 で実装した CoreWCFプロジェクトを実行した場合と変わらない。
CoreWCFを .NET Framework 4.8 で開発する人はいないと思いたい、、、
data:image/s3,"s3://crabby-images/16b1c/16b1c95f75df26c7791d7b31d517811e23ad9d75" alt=""
data:image/s3,"s3://crabby-images/06996/06996018ad7d0a2eb36d99f6cda213cbcf226b0e" alt=""
参考サイト
Core WCF プロジェクトサイト
GitHubに CoreWCF開発リポジトリがある。インストール手順などが分かる。
https://github.com/CoreWCF/CoreWCF
コメント