1. 程式人生 > 程式設計 >使用VSCode開發和除錯.NET Core程式的方法

使用VSCode開發和除錯.NET Core程式的方法

電腦不想裝幾十個G的 VS2017,那就用 VS Code 吧

目標:

  • 建立一個類庫專案 Skany.Core,並用 Nuget 引用第三方元件 Hash 實現加密演算法
  • 建立一個單元測試專案 Skany.Tests,引用類庫 Skany.Core,並測試其中的方法
  • 建立一個控制檯應用程式專案 Skany.Output,引用類庫 Skany.Core,並輸出方法執行結果
  • 建立一個解決方案 Skany.sln,包括以上三專案

環境

  • .NET Core SDK 2.2.202

開始

首先在 VS Code 安裝幾個擴充套件外掛

  • C#
  • C# Extensions
  • .NET Core Test Explorer

這三個外掛就可以做最基礎的開發了

使用VSCode開發和除錯.NET Core程式的方法

構建專案

建立解決方案資料夾 C:\Here\Skany
在 VS Code 中開啟這個資料夾
在 VS Code 中開啟終端(也可以在外部使用cmd或powershell)
接下來將使用 .NET Core CLI 命令建立專案

# 建立類庫專案
dotnet new classlib -n Skany.Core
# 建立控制檯應用程式
dotnet new console -n Skany.Output
# 建立xUnit單元測試專案
dotnet new xunit -n Skany.Tests
# 為 Output 新增 Core 引用(因為當前在解決方案目錄,而不是專案目錄,所以add後要加上專案名,以下同理)
dotnet add Skany.Output reference Skany.Core
# 為 Tests 新增 Core 引用
dotnet add Skany.Tests reference Skany.Core
# 為 Core 專案新增 Nuget 引用
dotnet add Skany.Core package Hash --version 4.0.0
# 建立解決方案 sln
dotnet new sln -n Skany
# 新增專案到解決方案
dotnet sln Skany.sln add Skany.Core
dotnet sln Skany.sln add Skany.Output
dotnet sln Skany.sln add Skany.Tests
# 編譯一下 Output 和 Tests 專案
dotnet build Skany.Output
dotnet build Skany.Tests

當不熟悉命令時,都可以通過 -h 或 --help 引數獲取幫助,比如我不知道單元測試專案的引數,就輸入 dotnet new -h 檢視 new 的選項
注:其實用第三方外掛(比如 vscode-solution-explorer)輕鬆實現以上命令的視覺化操作,這裡只是演示 .NET Core CLI 命令用法

建立完後的專案結構

SKANY
 | Skany.Core
  | Class1.cs
  | Skany.Core.csproj
 | Skany.Output
  | Program.cs
  | Skany.Output.csproj
 | Skany.Tests
  | UnitTest1.cs
  | Skany.Tests.csproj
 | Skany.sln

將 Core 專案中的 Class1.cs 改為 CryptHelper.cs,程式碼如下

using HashLibrary;

namespace Skany.Core
{
  public class CryptHelper
  {
    public static string HashPassword(string password,out string salt)
    {
      var hash = HashedPassword.New(password,hashLength: 50,saltLength: 10);
      salt = hash.Salt;
      return hash.Hash;
    }
    
    public static bool VerifyPassword(string password,string hashPassword,string salt)
    {
      var hash = new HashedPassword(hashPassword,salt);
      bool matches = hash.Check(password);
      return matches;
    }
  }
}

在 Tests 專案中別寫測試案例,將 UnitTest1.cs 改為 CryptUnitTest.cs,程式碼如下

using System;
using Xunit;

namespace Skany.Tests
{
  using Core;

  public class CryptUnitTest
  {
    [Theory]
    [InlineData("zhang")]
    [InlineData("baidu")]
    public void HashPasswordTest(string password)
    {
      string salt;
      var hashPassword = CryptHelper.HashPassword(password,out salt);
      Assert.NotNull(hashPassword);
      Assert.NotNull(salt);
      Assert.True(hashPassword.Length == CryptHelper.HashLength);
      Assert.True(salt.Length == CryptHelper.SaltLength);
      VerifyPasswordTest(password,hashPassword,salt);      
    }

    [Theory]
    [InlineData("zhang","ÁēÕĀ1fv¾ĒëÜĝ}f§¼kÈ$Æ7KĎĞĐMĬZĝČ9ËÅ«¢ÝĪÙØê£İ)¥jµQIįa","ïÛŀB³äĭonÊ")]
    [InlineData("baidu"," g©®Ģ¹Óäõ¥ģH»7ċuO¸%AOĮ©ĩ§8ĆKĄöĉĖß$µåˬüÖ=ĝĴ¶Cꨧh/","ĀĖ§į^H7Í_h")]
    public void VerifyPasswordTest(string password,string salt)
    {
      Assert.True(hashPassword.Length == CryptHelper.HashLength);
      Assert.True(salt.Length == CryptHelper.SaltLength);
      Assert.True(CryptHelper.VerifyPassword(password,salt));
    }
  }
}

單元測試

通過命令執行單元測試

dotnet test Skany.Tests

如果只想測試其中一個方法 HashPasswordTest

dotnet test Skany.Tests --filter HashPasswordTest

當然有視覺化的測試外掛,誰還用命令啊

使用VSCode開發和除錯.NET Core程式的方法

控制檯應用程式

在 Output 專案呼叫 Core.CryptHelper 輸出結果,程式碼如下

static void Main(string[] args)
{
   string salt = null;
   var password = "baidu";
   var hashPassword = CryptHelper.HashPassword(password,out salt);
   Console.WriteLine("Password => {0}",password);
   Console.WriteLine("HashPassword => {0}",hashPassword);
   Console.WriteLine("Salt => {0}",salt);

   //===================================

   var matchs = CryptHelper.VerifyPassword(password,salt);
   Console.WriteLine("Matchs: {0}",matchs);
   Console.ReadLine();
}

執行 Output 專案

dotnet run --project Skany.Output

使用VSCode開發和除錯.NET Core程式的方法

斷點除錯

在 Output/Program.cs 中第13行設定一個端點(滑鼠在行首點一下即可,再點一下移除斷點)

DEBUG面板配置選擇 .NET Core Launch (console),點選綠色的開始除錯按鈕,啟動除錯

使用VSCode開發和除錯.NET Core程式的方法

與 VS 中一樣,可以通過 F5/F10/F11 控制除錯流程,也可以新增 Watch 變數,滑鼠也可以感知變數值

如果開始測試後,警告提示啟動程式找不到,可以按提示(也可以點選介面齒輪按鈕)修改配置檔案 .vscode/launch.json
核對 program 節點路徑是否正確

使用VSCode開發和除錯.NET Core程式的方法

釋出

VS 中用工具釋出,釋出引數配置在 *Profile.pubxml,但 VS Code 中只能用命令

# 釋出Release配置,包括 .net core 執行時,分別釋出到 linux 和 windows
dotnet publish -c Release --self-contained -r linux-x64
dotnet publish -c Release --self-contained -r win-x64

# 釋出Release配置,包括 .net core 執行時,指定目標框架 netcoreapp2.2
dotnet publish -c Release -f netcoreapp2.2 --self-contained -r linux-x64
dotnet publish -c Release -f netcoreapp2.2 --self-contained -r win-x64

# 釋出Release配置,不包括 .net core 執行時
dotnet publish -c Release --self-contained false -r linux-x64
dotnet publish -c Release --self-contained false -r win-x64

# 釋出Release配置,不包括 .net core 執行時,指定輸出目錄
dotnet publish -c Release --self-contained false -r linux-x64 -o C:\Here\Spany\publish\linux-x64
dotnet publish -c Release --self-contained false -r win-x64 -o C:\Here\Spany\publish\win-x64

雖然 VS 無比強大,VS Code 小清醒,但是 VS Code 靈活擴充套件性強,用來開發前端或 .NET Core 專案,也是得心應手

到此這篇關於使用VSCode開發和除錯.NET Core程式的方法的文章就介紹到這了,更多相關VSCode開發和除錯.NET Core內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!