0

0

C# GitHub Actions配置方法 C#如何为.NET项目设置CI/CD

星降

星降

发布时间:2026-01-25 11:29:27

|

843人浏览过

|

来源于php中文网

原创

GitHub Actions中用dotnet/cli构建.NET项目需显式安装SDK、分步执行restore/build/test、指定测试路径、正确打包符号包、安全注入密钥。

c# github actions配置方法 c#如何为.net项目设置ci/cd

GitHub Actions中用dotnet/cli构建.NET项目的关键步骤

默认的 .github/workflows/dotnet.yml 模板能跑通,但容易在 restore 或 publish 阶段失败,根本原因是没显式指定 SDK 版本和运行时目标。CI 环境不保证预装你本地用的 .NET SDK,尤其当你用的是 .NET 6+ 的隐式 usings 或 Nullable 全局设置时。

实操建议:

  • 在 workflow 文件顶部用 actions/setup-dotnet@v4 显式安装所需版本,例如 dotnet-version: '8.0.x'x 表示允许补丁更新)
  • dotnet restore 必须在 dotnet build 前单独执行,且推荐加 --no-cache 避免 CI 缓存污染
  • 若项目含多个 .csproj(如类库 + WebAPI + Tests),用 dotnet build ./MySolution.sln 更可靠,而非对单个项目调用 build
  • 测试阶段务必用 dotnet test --no-build,避免重复编译;若需代码覆盖率,再额外加 --collect:"XPlat Code Coverage" 并配合 coverlet.collector

如何让 GitHub Actions 正确识别并运行 xUnit/NUnit 测试

常见现象是 workflow 显示 Build succeeded,但测试步骤直接跳过,或报错 No test assemblies found。这通常不是测试没写,而是 dotnet test 没找到含 [Fact][Test] 的程序集。

实操建议:

  • 确保测试项目引用了对应框架包:Microsoft.NET.Test.Sdk + xunit(或 NUnit3TestAdapter
  • 在 workflow 中明确指定测试项目路径,例如 dotnet test ./src/MyApp.Tests/MyApp.Tests.csproj,不要只写 dotnet test
  • 若测试项目依赖本地 NuGet 包或 project reference,确认 dotnet restore 已覆盖全部项目(可加 --source 参数指向 private feed)
  • 遇到 System.DllNotFoundException 类错误,大概率是测试中用了 Windows-only API,需在 job 中设 runs-on: windows-latest,或改用跨平台等价实现

发布带符号文件(.pdb)和 NuGet 包的注意事项

本地 dotnet pack 能生成 .nupkg 和 .snupkg,但 CI 中常漏掉符号包,或上传后 NuGet.org 不认。核心问题在于:符号包必须与主包完全匹配(相同 version、assembly version、hash),且需用 dotnet nuget push 单独上传。

Picsart
Picsart

Picsart是全球最大的数字创作平台。

下载

实操建议:

  • 打包时加参数:dotnet pack --configuration Release --include-symbols --symbol-package-format snupkg
  • 生成的 .snupkg 文件不会自动上传,必须显式调用 dotnet nuget push *.snupkg -s https://api.nuget.org/v3/index.json -k ${{ secrets.NUGET_API_KEY }}
  • 若项目使用 Directory.Build.props 控制 Version,确保 CI 中未被 GITHUB_RUN_NUMBER 等变量意外覆盖;建议用 dotnet msbuild -getProperty:Version 验证实际值
  • 符号服务器验证:上传后访问 https://api.nuget.org/v3/debug/symbols/YourPackage/{version}/YourPackage.pdb/{hash}/YourPackage.pdb,看是否返回 200

敏感配置(连接字符串、密钥)的安全注入方式

ConnectionStrings:Default 写进 appsettings.json 并提交到仓库是高危操作。GitHub Actions 提供 secrets,但不能直接映射为环境变量传给 dotnet run —— 因为 .NET 默认只从 DOTNET_*ASPNETCORE_* 前缀变量读取配置。

实操建议:

  • env: 将 secret 注入 job,再通过 --environmentASPNETCORE_ENVIRONMENT=Production 触发 appsettings.Production.json 加载
  • 更灵活的方式是运行时替换:用 sed -i "s/PLACEHOLDER/${{ secrets.DB_CONN }}/g" appsettings.json(Linux/macOS)或 PowerShell 的 (Get-Content appsettings.json) -replace ... | Set-Content(Windows)
  • 若用 Azure Key Vault 或 AWS Secrets Manager,建议在 startup 中用 AddAzureKeyVaultAddSecretsManager,而非提前解密塞进 config 文件
  • 切记:所有含 secret 的 job 必须设 if: github.event_name == 'push' && github.repository == 'owner/repo',防止 fork PR 泄露
实际配置中最容易被忽略的,是 setup-dotnet 的版本通配符(比如写成 '7.0' 而非 '7.0.x')导致后续 patch 更新失败,以及测试项目未显式指定路径导致 dotnet test 扫描空目录。这些细节不报错,但会让 pipeline 表面成功、实际失能。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

417

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

769

2023.08.22

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

719

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

431

2024.06.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

278

2023.08.03

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

45

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.7万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号