mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-25 06:43:15 +01:00
4.1 KiB
4.1 KiB
date | title | slug | weight | draft | toc | menu | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
2021-07-20T00:00:00+00:00 | NuGet 软件包注册表 | nuget | 80 | false | false |
|
NuGet 软件包注册表
发布适用于您的用户或组织的 NuGet 软件包。软件包注册表支持 V2 和 V3 API 协议,并且您还可以使用 NuGet 符号软件包。
目录
{{< toc >}}
要求
要使用 NuGet 软件包注册表,您可以使用命令行界面工具,以及各种集成开发环境(IDE)中的 NuGet 功能,如 Visual Studio。有关 NuGet 客户端的更多信息,请参阅官方文档。
以下示例使用 dotnet nuget
工具。
配置软件包注册表
要注册软件包注册表,您需要配置一个新的NuGet源:
dotnet nuget add source --name {source_name} --username {username} --password {password} https://gitea.example.com/api/packages/{owner}/nuget/index.json
参数 | 描述 |
---|---|
source_name |
所需源名称 |
username |
您的Gitea用户名 |
password |
您的Gitea密码。如果您使用2FA或OAuth,请使用[个人访问令牌]({{< relref "doc/development/api-usage.zh-cn.md#通过-api-认证" >}})代替密码。 |
owner |
软件包的所有者 |
例如:
dotnet nuget add source --name gitea --username testuser --password password123 https://gitea.example.com/api/packages/testuser/nuget/index.json
您可以在不提供凭据的情况下添加源,并在发布软件包时使用--api-key参数。在这种情况下,您需要提供[个人访问令牌]({{< relref "doc/development/api-usage.zh-cn.md#通过-api-认证" >}})。
发布软件包
通过运行以下命令发布软件包:
dotnet nuget push --source {source_name} {package_file}
参数 | 描述 |
---|---|
source_name |
所需源名称 |
package_file |
软件包 .nupkg 文件的路径。 |
例如:
dotnet nuget push --source gitea test_package.1.0.0.nupkg
如果已经存在相同名称和版本的软件包,您无法发布该软件包。您必须先删除现有的软件包。
符号软件包
NuGet 软件包注册表支持构建用于符号服务器的符号软件包。客户端可以请求嵌入在符号软件包(.snupkg
)中的 PDB 文件。
为此,请将 NuGet 软件包注册表注册为符号源:
https://gitea.example.com/api/packages/{owner}/nuget/symbols
参数 | 描述 |
---|---|
owner |
软件包注册表的所有者 |
例如:
https://gitea.example.com/api/packages/testuser/nuget/symbols
安装软件包
要从软件包注册表安装 NuGet 软件包,请执行以下命令:
dotnet add package --source {source_name} --version {package_version} {package_name}
参数 | 描述 |
---|---|
source_name |
所需源名称 |
package_name |
软件包名称 |
package_version |
软件包版本。 |
例如:
dotnet add package --source gitea --version 1.0.0 test_package
支持的命令
dotnet add
dotnet nuget push
dotnet nuget delete