真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何使用VSCode開(kāi)發(fā)和調(diào)試.NETCore程序-創(chuàng)新互聯(lián)

這篇“如何使用VSCode開(kāi)發(fā)和調(diào)試.NET Core程序”文章,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要參考一下,對(duì)于“{**}”,小編整理了以下知識(shí)點(diǎn),請(qǐng)大家跟著小編的步伐一步一步的慢慢理解,接下來(lái)就讓我們進(jìn)入主題吧。

創(chuàng)新互聯(lián)專(zhuān)業(yè)成都網(wǎng)站制作、成都做網(wǎng)站、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè),集網(wǎng)站策劃、網(wǎng)站設(shè)計(jì)、網(wǎng)站制作于一體,網(wǎng)站seo、網(wǎng)站優(yōu)化、網(wǎng)站營(yíng)銷(xiāo)、軟文營(yíng)銷(xiāo)等專(zhuān)業(yè)人才根據(jù)搜索規(guī)律編程設(shè)計(jì),讓網(wǎng)站在運(yùn)行后,在搜索中有好的表現(xiàn),專(zhuān)業(yè)設(shè)計(jì)制作為您帶來(lái)效益的網(wǎng)站!讓網(wǎng)站建設(shè)為您創(chuàng)造效益。

vscode有什么用

Visual Studio Code 是一個(gè)運(yùn)行于 OS X,Windows和 Linux 之上的,針對(duì)于編寫(xiě)現(xiàn)代 web 和云應(yīng)用的跨平臺(tái)編輯器,它為開(kāi)發(fā)者們提供了對(duì)多種編程語(yǔ)言的內(nèi)置支持,并且正如 Microsoft 在Build 大會(huì)的 keynote 中所指出的,這款編輯器也會(huì)為這些語(yǔ)言都提供了豐富的代碼補(bǔ)全和導(dǎo)航功能。

目標(biāo):

  • 創(chuàng)建一個(gè)類(lèi)庫(kù)項(xiàng)目 Skany.Core,并用 Nuget 引用第三方組件 Hash 實(shí)現(xiàn)加密算法

  • 創(chuàng)建一個(gè)單元測(cè)試項(xiàng)目 Skany.Tests,引用類(lèi)庫(kù) Skany.Core,并測(cè)試其中的方法

  • 創(chuàng)建一個(gè)控制臺(tái)應(yīng)用程序項(xiàng)目 Skany.Output,引用類(lèi)庫(kù) Skany.Core,并輸出方法執(zhí)行結(jié)果

  • 創(chuàng)建一個(gè)解決方案 Skany.sln,包括以上三項(xiàng)目

環(huán)境

  • .NET Core SDK 2.2.202

開(kāi)始

首先在 VS Code 安裝幾個(gè)擴(kuò)展插件

  • C#

  • C# Extensions

  • .NET Core Test Explorer

這三個(gè)插件就可以做最基礎(chǔ)的開(kāi)發(fā)了

如何使用VSCode開(kāi)發(fā)和調(diào)試.NET Core程序

構(gòu)建項(xiàng)目

創(chuàng)建解決方案文件夾 C:\Here\Skany
在 VS Code 中打開(kāi)這個(gè)文件夾
在 VS Code 中打開(kāi)終端(也可以在外部使用cmd或powershell)
接下來(lái)將使用 .NET Core CLI 命令創(chuàng)建項(xiàng)目

# 創(chuàng)建類(lèi)庫(kù)項(xiàng)目
dotnet new classlib -n Skany.Core
# 創(chuàng)建控制臺(tái)應(yīng)用程序
dotnet new console -n Skany.Output
# 創(chuàng)建xUnit單元測(cè)試項(xiàng)目
dotnet new xunit -n Skany.Tests
# 為 Output 添加 Core 引用(因?yàn)楫?dāng)前在解決方案目錄,而不是項(xiàng)目目錄,所以add后要加上項(xiàng)目名,以下同理)
dotnet add Skany.Output reference Skany.Core
# 為 Tests 添加 Core 引用
dotnet add Skany.Tests reference Skany.Core
# 為 Core 項(xiàng)目添加 Nuget 引用
dotnet add Skany.Core package Hash --version 4.0.0
# 創(chuàng)建解決方案 sln
dotnet new sln -n Skany
# 添加項(xiàng)目到解決方案
dotnet sln Skany.sln add Skany.Core
dotnet sln Skany.sln add Skany.Output
dotnet sln Skany.sln add Skany.Tests
# 編譯一下 Output 和 Tests 項(xiàng)目
dotnet build Skany.Output
dotnet build Skany.Tests

當(dāng)不熟悉命令時(shí),都可以通過(guò) -h 或 --help 參數(shù)獲取幫助,比如我不知道單元測(cè)試項(xiàng)目的參數(shù),就輸入 dotnet new -h 查看 new 的選項(xiàng)
注:其實(shí)用第三方插件(比如 vscode-solution-explorer)輕松實(shí)現(xiàn)以上命令的可視化操作,這里只是演示 .NET Core CLI 命令用法

創(chuàng)建完后的項(xiàng)目結(jié)構(gòu)

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 項(xiàng)目中的 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 項(xiàng)目中別寫(xiě)測(cè)試案例,將 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));
    }
  }
}

單元測(cè)試

通過(guò)命令執(zhí)行單元測(cè)試

dotnet test Skany.Tests

如果只想測(cè)試其中一個(gè)方法 HashPasswordTest

dotnet test Skany.Tests --filter HashPasswordTest

當(dāng)然有可視化的測(cè)試插件,誰(shuí)還用命令啊

如何使用VSCode開(kāi)發(fā)和調(diào)試.NET Core程序

控制臺(tái)應(yīng)用程序

在 Output 項(xiàng)目調(diào)用 Core.CryptHelper 輸出結(jié)果,代碼如下

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();
}

運(yùn)行 Output 項(xiàng)目

dotnet run --project Skany.Output

如何使用VSCode開(kāi)發(fā)和調(diào)試.NET Core程序

斷點(diǎn)調(diào)試

在 Output/Program.cs 中第13行設(shè)置一個(gè)端點(diǎn)(鼠標(biāo)在行首點(diǎn)一下即可,再點(diǎn)一下移除斷點(diǎn))

DEBUG面板配置選擇 .NET Core Launch (console),點(diǎn)擊綠色的開(kāi)始調(diào)試按鈕,啟動(dòng)調(diào)試

如何使用VSCode開(kāi)發(fā)和調(diào)試.NET Core程序

與 VS 中一樣,可以通過(guò) F5/F10/F11 控制調(diào)試流程,也可以添加 Watch 變量,鼠標(biāo)也可以感知變量值

如果開(kāi)始測(cè)試后,警告提示啟動(dòng)程序找不到,可以按提示(也可以點(diǎn)擊界面齒輪按鈕)修改配置文件 .vscode/launch.json
核對(duì) program 節(jié)點(diǎn)路徑是否正確

如何使用VSCode開(kāi)發(fā)和調(diào)試.NET Core程序

發(fā)布

VS 中用工具發(fā)布,發(fā)布參數(shù)配置在 *Profile.pubxml,但 VS Code 中只能用命令

# 發(fā)布Release配置,包括 .net core 運(yùn)行時(shí),分別發(fā)布到 linux 和 windows
dotnet publish -c Release --self-contained -r linux-x64
dotnet publish -c Release --self-contained -r win-x64

# 發(fā)布Release配置,包括 .net core 運(yùn)行時(shí),指定目標(biāo)框架 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

# 發(fā)布Release配置,不包括 .net core 運(yùn)行時(shí)
dotnet publish -c Release --self-contained false -r linux-x64
dotnet publish -c Release --self-contained false -r win-x64

# 發(fā)布Release配置,不包括 .net core 運(yùn)行時(shí),指定輸出目錄
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 無(wú)比強(qiáng)大,VS Code 小清醒,但是 VS Code 靈活擴(kuò)展性強(qiáng),用來(lái)開(kāi)發(fā)前端或 .NET Core 項(xiàng)目,也是得心應(yīng)手

以上是“如何使用VSCode開(kāi)發(fā)和調(diào)試.NET Core程序”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


分享名稱(chēng):如何使用VSCode開(kāi)發(fā)和調(diào)試.NETCore程序-創(chuàng)新互聯(lián)
本文路徑:http://weahome.cn/article/idsss.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部