forked from mirror/codeberg-forgejo
115 lines
4.0 KiB
Markdown
115 lines
4.0 KiB
Markdown
---
|
||
date: "2021-07-20T00:00:00+00:00"
|
||
title: "NuGet 软件包注册表"
|
||
slug: "nuget"
|
||
sidebar_position: 80
|
||
draft: false
|
||
toc: false
|
||
menu:
|
||
sidebar:
|
||
parent: "packages"
|
||
name: "NuGet"
|
||
sidebar_position: 80
|
||
identifier: "nuget"
|
||
---
|
||
|
||
# NuGet 软件包注册表
|
||
|
||
发布适用于您的用户或组织的 [NuGet](https://www.nuget.org/) 软件包。软件包注册表支持 V2 和 V3 API 协议,并且您还可以使用 [NuGet 符号软件包](https://docs.microsoft.com/en-us/nuget/create-packages/symbol-packages-snupkg)。
|
||
|
||
## 要求
|
||
|
||
要使用 NuGet 软件包注册表,您可以使用命令行界面工具,以及各种集成开发环境(IDE)中的 NuGet 功能,如 Visual Studio。有关 NuGet 客户端的更多信息,请参[阅官方文档](https://docs.microsoft.com/en-us/nuget/install-nuget-client-tools)。
|
||
以下示例使用 `dotnet nuget` 工具。
|
||
|
||
## 配置软件包注册表
|
||
|
||
要注册软件包注册表,您需要配置一个新的NuGet源:
|
||
|
||
```shell
|
||
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,请使用[个人访问令牌](development/api-usage.md#通过-api-认证)代替密码。 |
|
||
| `owner` | 软件包的所有者 |
|
||
|
||
例如:
|
||
|
||
```shell
|
||
dotnet nuget add source --name gitea --username testuser --password password123 https://gitea.example.com/api/packages/testuser/nuget/index.json
|
||
```
|
||
|
||
您可以在不提供凭据的情况下添加源,并在发布软件包时使用--api-key参数。在这种情况下,您需要提供[个人访问令牌](development/api-usage.md#通过-api-认证)。
|
||
|
||
## 发布软件包
|
||
|
||
通过运行以下命令发布软件包:
|
||
|
||
```shell
|
||
dotnet nuget push --source {source_name} {package_file}
|
||
```
|
||
|
||
| 参数 | 描述 |
|
||
| -------------- | ---------------------------- |
|
||
| `source_name` | 所需源名称 |
|
||
| `package_file` | 软件包 `.nupkg` 文件的路径。 |
|
||
|
||
例如:
|
||
|
||
```shell
|
||
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 软件包,请执行以下命令:
|
||
|
||
```shell
|
||
dotnet add package --source {source_name} --version {package_version} {package_name}
|
||
```
|
||
|
||
| 参数 | 描述 |
|
||
| ----------------- | ------------ |
|
||
| `source_name` | 所需源名称 |
|
||
| `package_name` | 软件包名称 |
|
||
| `package_version` | 软件包版本。 |
|
||
|
||
例如:
|
||
|
||
```shell
|
||
dotnet add package --source gitea --version 1.0.0 test_package
|
||
```
|
||
|
||
## 支持的命令
|
||
|
||
```
|
||
dotnet add
|
||
dotnet nuget push
|
||
dotnet nuget delete
|
||
```
|