dotnet开发

1、测试是否安装了sdk

# 查看dotnet版本
$ dotnet --version
6.0.401

# 可以用vs code打开当前文件夹
$ code .

# 查看所有的sdk
$ dotnet --list-sdks
6.0.401 [C:\Program Files\dotnet\sdk]

2、安装c# vs code 插件

  • 打开插件后,搜索c#
    • C#(必装)
    • C# Extensions(必装) :增加一些快速创建类、接口、枚举等菜单
    • Visual Studio IntelliCode(必装) :来观察和查找众多开源GitHub项目中使用的模式,并在编码时提供建议
    • NuGet Package Manager(不建议安装)
    • csharpwebapi(选装)
    • Dotnet Core Essentials(选装)
    • ASP.NET Core Snippets(选装)

3、创建项目

  • 查看帮助

    $ dotnet -h
    使用情况: dotnet [runtime-options] [path-to-application] [arguments]
    
    执行 .NET 应用程序。
    
    runtime-options:
      --additionalprobingpath <path>   要探测的包含探测策略和程序集的路径。
      --additional-deps <path>         指向其他 deps.json 文件的路径。
      --depsfile                       指向 <application>.deps.json 文件的路径。
      --fx-version <version>           要用于运行应用程序的安装版共享框架的版本。
      --roll-forward <setting>         前滚至框架版本(LatestPatch, Minor, LatestMinor, Major, LatestMajor, Disable)。
      --runtimeconfig                  指向 <application>.runtimeconfig.json 文件的路径。
    
    path-to-application:
      要执行的应用程序 .dll 文件的路径。
    
    使用情况: dotnet [sdk-options] [command] [command-options] [arguments]
    
    执行 .NET SDK 命令。
    
    sdk-options:
      -d|--diagnostics  启用诊断输出。
      -h|--help         显示命令行帮助。
      --info            显示 .NET 信息。
      --list-runtimes   显示安装的运行时。
      --list-sdks       显示安装的 SDK。
      --version         显示使用中的 .NET SDK 版本。
    
    SDK 命令:
      add               将包或引用添加到 .NET 项目。
      build             生成 .NET 项目。
      build-server      与由生成版本启动的服务器进行交互。
      clean             清理 .NET 项目的生成输出。
      format            将样式首选项应用到项目或解决方案。
      help              显示命令行帮助。
      list              列出 .NET 项目的项目引用。
      msbuild           运行 Microsoft 生成引擎(MSBuild)命令。
      new               创建新的 .NET 项目或文件。
      nuget             提供其他 NuGet 命令。
      pack              创建 NuGet 包。
      publish           发布 .NET 项目进行部署。
      remove            从 .NET 项目中删除包或引用。
      restore           还原 .NET 项目中指定的依赖项。
      run               生成并运行 .NET 项目输出。
      sdk               管理 .NET SDK 安装。
      sln               修改 Visual Studio 解决方案文件。
      store             在运行时包存储中存储指定的程序集。
      test              使用 .NET 项目中指定的测试运行程序运行单元测试。
      tool              安装或管理扩展 .NET 体验的工具。
      vstest            运行 Microsoft 测试引擎(VSTest)命令。
      workload          管理可选工作负荷。
    
    捆绑工具中的其他命令:
      dev-certs         创建和管理开发证书。
      fsi               启动 F# 交互/执行 F# 脚本。
      sql-cache         SQL Server cache command-line tools.
      user-secrets      管理开发用户密码。
      watch             启动文件观察程序,它会在文件发生更改时运行命令。
    
    运行 "dotnet [command] --help",获取有关命令的详细信息。
    
  • 创建项目的步骤

## 创建文件夹
$ mkdir HisApi

## 进入文件夹
$ cd HisApi

## 创建解决方案  dotnet new sln -o blog   这个命令是创建个文件夹的解决方案 其中 -o 表示输出文件夹
## --name可以用 -n代替    
$ dotnet new sln --name HisApi
已成功创建模板“解决方案文件”。

## 创建webapi项目  其中 -o 表示输出文件夹
## dotnet new console -n myPro.App 创建一个控制台项目
$ dotnet new webapi -o cn.tjhis.WebApi --no-https
已成功创建模板“ASP.NET Core Web API”。

正在处理创建后操作...
在 D:\vscode\HisApi\cn.tjhis.WebApi\cn.tjhis.WebApi.csproj 上运行 “dotnet restore”...
  正在确定要还原的项目…

  已还原 D:\vscode\HisApi\cn.tjhis.WebApi\cn.tjhis.WebApi.csproj (用时 35.54 sec)。
已成功还原。

## 将api项目添加到解决方案中
$ dotnet sln add ./cn.tjhis.WebApi/cn.tjhis.WebApi.csproj
已将项目“cn.tjhis.WebApi\cn.tjhis.WebApi.csproj”添加到解决方案中。

## 编译和运行,也可以直接F5运行
$ dotnet run --project ./cn.tjhis.WebApi/cn.tjhis.WebApi.csproj
正在生成...
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://localhost:5150
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Development
info: Microsoft.Hosting.Lifetime[0]
      Content root path: D:\vscode\HisApi\cn.tjhis.WebApi\

## 创建类库
$ dotnet new classlib -o cn.tjhis.Common
已成功创建模板“类库”。

## 将类库添加到解决方案中
$ dotnet sln add ./cn.tjhis.Common/cn.tjhis.Common.csproj
已将项目“cn.tjhis.Common\cn.tjhis.Common.csproj”添加到解决方案中。

## WebApi添加引用Common  如果是引用项目,则使用关键字reference;如果是引用包,则使用package
$ dotnet add ./cn.tjhis.WebApi/cn.tjhis.WebApi.csproj reference ./cn.tjhis.Common/cn.tjhis.Common.csproj
已将引用“..\cn.tjhis.Common\cn.tjhis.Common.csproj”添加到项目。

## 编译
$ dotnet build
MSBuild version 17.3.1+2badb37d1 for .NET
  正在确定要还原的项目…
  所有项目均是最新的,无法还原。
  cn.tjhis.Common -> D:\vscode\HisApi\cn.tjhis.Common\bin\Debug\net6.0\cn.tjhis.Common.dll
  cn.tjhis.WebApi -> D:\vscode\HisApi\cn.tjhis.WebApi\bin\Debug\net6.0\cn.tjhis.WebApi.dll

已成功生成。
    0 个警告
    0 个错误

已用时间 00:00:01.31

## 发布
$ dotnet publish
MSBuild version 17.3.1+2badb37d1 for .NET
  正在确定要还原的项目…
  所有项目均是最新的,无法还原。
  cn.tjhis.Common -> D:\vscode\HisApi\cn.tjhis.Common\bin\Debug\net6.0\cn.tjhis.Common.dll
  cn.tjhis.Common -> D:\vscode\HisApi\cn.tjhis.Common\bin\Debug\net6.0\publish\
  cn.tjhis.WebApi -> D:\vscode\HisApi\cn.tjhis.WebApi\bin\Debug\net6.0\cn.tjhis.WebApi.dll
  cn.tjhis.WebApi -> D:\vscode\HisApi\cn.tjhis.WebApi\bin\Debug\net6.0\publish\

## 安装工具httprepl
$ dotnet tool install -g Microsoft.dotnet-httprepl
可使用以下命令调用工具: httprepl
已成功安装工具“microsoft.dotnet-httprepl”(版本“6.0.0”)。

## 查看是否安装充公
$ httprepl -v
Welcome to HttpRepl 6.0!

## 另开一个终端,不能使用git bash,使用cmd
$ httprepl http://localhost:5150
(Disconnected)> connect http://localhost:5150
Using a base address of http://localhost:5150/
Using OpenAPI description at http://localhost:5150/swagger/v1/swagger.json
For detailed tool info, see https://aka.ms/http-repl-doc

http://localhost:5150/> ls
.                 []
WeatherForecast   [GET]

http://localhost:5150/> cd WeatherForecast
/WeatherForecast    [GET]

http://localhost:5150/WeatherForecast> get
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Date: Thu, 24 Nov 2022 12:51:34 GMT
Server: Kestrel
Transfer-Encoding: chunked

[
  {
    "date": 2022-11-25 20:51:35,
    "temperatureC": 47,
    "temperatureF": 116,
    "summary": "Scorching"
  },
  {
    "date": 2022-11-26 20:51:35,
    "temperatureC": 20,
    "temperatureF": 67,
    "summary": "Freezing"
  },
  {
    "date": 2022-11-27 20:51:35,
    "temperatureC": 0,
    "temperatureF": 32,
    "summary": "Sweltering"
  },
  {
    "date": 2022-11-28 20:51:35,
    "temperatureC": 31,
    "temperatureF": 87,
    "summary": "Mild"
  },
  {
    "date": 2022-11-29 20:51:35,
    "temperatureC": 43,
    "temperatureF": 109,
    "summary": "Scorching"
  }
]

## 列出当前项目的引用名称、包名称
dotnet list reference
dotnet list package
## 移除当前项目的引用名称、包名称
dotnet remove reference
dotnet remove package
## 向当前项目添加引用、包
dotnet add reference
dotnet add package

## 需要进入对应的项目目录内才可以引用
Administrator@wanghx MINGW64 /d/vscode/HisApi/cn.tjhis.Common
$ dotnet add package SqlSugarCore

原文地址:http://www.cnblogs.com/his365/p/16923541.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性