1. 程式人生 > >使用 VS Code 和開發和調試 .NET Core 程序

使用 VS Code 和開發和調試 .NET Core 程序

pre 執行 選項 tel 也有 img 構建 ret hashlib

電腦不想裝幾十個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

當然你還可以安裝更多的插件,也有助於開發

技術分享圖片

構建項目

創建解決方案文件夾 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 的選項
註:其實有插件可以實現以上命令的可視化操作

創建完後的項目結構

 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 hashPassword, string salt)
        {
            Assert.True(hashPassword.Length == CryptHelper.HashLength);
            Assert.True(salt.Length == CryptHelper.SaltLength);
            Assert.True(CryptHelper.VerifyPassword(password, hashPassword, salt));
        }
    }
}

單元測試

通過命令執行單元測試

dotnet test Skany.Tests

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

dotnet test --filter HashPasswordTest

當然有可視化的測試插件,誰還用命令啊

技術分享圖片

控制臺應用程序

在 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, hashPassword, salt);
     Console.WriteLine("Matchs: {0}", matchs);
     Console.ReadLine();
}

運行 Output 項目

dotnet run --project Skany.Output

技術分享圖片

斷點調試

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

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

技術分享圖片

與 VS 中一樣,可以通過 F5/F10/F11 控制調試流程,也可以添加 Watch 變量,鼠標也可以感知變量值

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

技術分享圖片

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

使用 VS Code 和開發和調試 .NET Core 程序