• 如何将项目打包上传到NuGet服务器(图文教程)?


    cover.png

    作者:西瓜程序猿
    主页传送门:https://www.cnblogs.com/kimiliucn


    前言

    在我写[在.NET Framework中使用RocketMQ(阿里云版)]这篇博客的时候,因为封装了很多代码在单独的DLL中,包括生产者、消费者以及官方SDK等等,然后都在博客中体现出来导致博客大量代码,然后有位读者就建议打包成NuGet包,大家也可以直接安装引入调用,我也觉得很不错,于是就有了这篇文章啦!
    image.png

    那NuGet是什么呢?NuGet是.NET的包管理器,NuGet客户端工具提供了生成和使用包的能力,NuGet库是所有包作者和消费者使用的中心包存储库。那来看一下如何将代码打包上传到NuGet服务器吧!


    一、提前准备

    1.1-登录NuGet官网

    (1)打开官方网址,然后点击【Sign in with Microsoft】使用微软账号登录。

    登录网址:https://www.nuget.org/users/account/LogOn

    image.png
    (2)输入微软邮箱,然后点击【下一步】进行登录。
    image.png


    1.2-创建API Key秘钥

    (1)点击右上角用户名称,然后点击【API Keys】。
    image.png
    (2)然后点击【Create】,在输入必填的信息。【KeyName】可以填项目包名,也可以自定义命名,唯一就行了。然后【Glob Pattern】可以填写"*"来替换任何序列。
    image.png
    API密钥是一种令牌,可以向NuGet Gallery识别身份。NuGet命令行实用程序允许使用API密钥向库提交NuGet包以进行身份验证。
    注意要对API密钥保密!如果某个密钥意外泄露,可以随时生成一个新密钥。如有必要,还可以删除现有的API密钥。

    注意:要将包推送到nuget.org,必须使用nuget.exe v4.1.0或更高版本,它实现了所需的nuget协议。

    (3)然后点击【Copy】复制秘钥,请自行将秘钥保存好,后面会用到。
    image.png


    二、创建与打包项目

    (1) [西瓜程序猿]创建一个名为【Kimi.RocketMQ.NET】类库,目标框架使用【.NET Framework 4.8】,输出类型为【类库】。
    image.png
    (2)代码编写后,然后使用Release模式生成dll。(我这没有依赖其他任何外部包,如果依赖了,上传打包前需要进行配置)
    image.png
    image.png
    (3) 打开【AssemblyInfo.cs】文件,设置相关属性值和版本。
    image.png
    (4)为了方便管理文件,我们可以单独新建一个文件夹保存要上传的文件。[西瓜程序猿]这里新建名为【Kimi.RocketMQ.NET】的文件夹。
    将编译好的DLL,放在此文件夹。
    image.png
    然后新建一个【readme.md】用来介绍文件,会在包管理中显示此文件的内容
    image.png
    在设计一个ICON(图标需要上传到线上,然后将外网能访问的图片地址进行上传到NuGet),作为nuget包的图标。大小建议是128px或256px(注意:文件格式必须是.png)。
    image.png
    文件夹截图:
    image.png


    三、上传NuGet

    [西瓜程序猿]准备了要上传NuGet上传使用的资源包,如果大家要下载最新版请去官网下载。可以访问下载(如果失效了,请联系我)。

    下载地址(编码:0m7AToKX):https://yongteng.lanzoub.com/ip4nN17bdtbi
    密码: 5jh4

    文件截图:
    image.png


    3.1-使用可视化方式【推荐】

    3.1.1-下载工具

    (1)首页将下载好资源包里面的【PackageExplorer.4.4.72】文件夹,复制到一个固定的地方,不要删除了。[西瓜程序猿]放在【D:\RuanjianAnzhuang\PackageExplorer.4.4.72】路径下了,我们打开【NuGetPackageExplorer.exe】应用程序。
    image.png
    如果需要在官网下载最新版,可以点击这个链接:

    官方下载:https://www.microsoft.com/zh-cn/p/nuget-package-explorer/9wzdncrdmdm3?activetab=pivot:overviewtab

    (2)然后点击【Create a new package (CtrI+N)】创建一个新Package。
    image.png


    3.1.2-配置相关包

    (1)新增【lib】文件夹。
    image.png
    image.png
    (2)然后新选择响应的框架版本,会自动创建版本文件夹,比如[西瓜程序猿]创建的【Kimi.RocketMQ.NET】包是给.NET Framework使用的,我这边就先创建这些。
    image.png
    image.png
    也可以自己创建文件夹,比如没有4.8版本,那可以自行创建一个为【net48】文件夹。
    image.png
    image.png
    (3)然后再每个文件夹中,添加之前打包后的DLL包。
    image.png
    添加好文件后,目录是这样的:
    image.png
    (3)然后编辑上传数据,选择【Edit】——>【Edit Metadata】,然后填写相关信息。
    image.png
    image.png
    (4)然后如果有依赖性,还需添加项目依赖,依赖哪些框架比如.NETFramework,.NETStandard等。
    image.png
    (5)然后编辑完成,看一下效果。
    image.png
    (5)点击这个可以看到配置的源代码。
    image.png
    代码:

    
    <package xmlns="http://schemas.microsoft.com/packaging/2012/06/nuspec.xsd">
      <metadata>
        <id>Kimi.RocketMQ.NETid>
        <version>1.0.9version>
        <title>Kimi.RocketMQ.NETtitle>
        <authors>西瓜程序猿authors>
        <owners>西瓜程序猿owners>
        <requireLicenseAcceptance>falserequireLicenseAcceptance>
        <licenseUrl>https://licenses.nuget.org/MITlicenseUrl>
        <projectUrl>https://www.cnblogs.com/kimiliucn/p/17662052.htmlprojectUrl>
        <iconUrl>http://xxx.xxx.xxx.192:7980/Temp_Storage/Images/2023-08-31/9dd8dbcccd314a31835c69ea344b0216.pngiconUrl>
        <description>.NET Framework使用RocketMQ(阿里云版)description>
        <summary>.NET Framework使用RocketMQ(阿里云版)summary>
        <releaseNotes>发布1.0.9releaseNotes>
        <copyright>Copyright © 2023 西瓜程序猿copyright>
        <language>zh-CNlanguage>
        <tags>Kimi.RocketMQ.NETtags>
        <dependencies>
          <group targetFramework=".NETFramework4.8" />
        dependencies>
      metadata>
    package>
    

    (6)点击【File】——>【Save As】保存nupkg文件。
    image.png
    文件截图:
    image.png


    3.3-上传到nuget服务器

    (1)点击【File】——>【Publish】。
    image.png
    (2)【Publish key or PAT】填写秘钥Key,然后点击【Publish】发布,只要没报错就表示上传成功了。
    image.png
    (3)稍等1-3分钟,然后会收到上传成功的邮件通知。
    image.png
    (4)然后可以去官网看看是否此版本发布成功了。

    [西瓜程序猿]案例:https://www.nuget.org/packages/Kimi.RocketMQ.NET/

    image.png


    3.2-使用命令方式

    3.2.1-下载软件配置环境

    (1)点击下面地址下载软件,选择比较新的版本即可(如果是通过上面的链接下载了资源包,就可以跳过这一步了,直接看第二步骤)。

    官网下载:https://www.nuget.org/downloads

    image.png
    下载好后得到:
    image.png
    (2)把下载好的【nuget.exe】这个文件,放在一个固定的地方,不要删了。[西瓜程序猿]放在这个目录【D:\RuanjianAnzhuang\nuget_client】。
    image.png
    (3)然后来配置环境变量。点击【此电脑】,右击【属性】——>高级系统设置——>环境变量——>系统变量——>选择Path——>编辑——>新建——>填写【D:\RuanjianAnzhuang\nuget_client】,大家根据自己路径配置哈。
    image.png
    (4)测试是否配置成功。按【win+R】键,然后输入cmd,在输入【nuget】命令查看。

    命令:nuget

    配置成功截图:
    image.png
    配置失败截图:
    image.png


    3.2.2-配置全局Push源地址

    配置模拟的push源为nuget.org,输入以下命令:

    nuget config -Set DefaultPushSource=nuget.org


    3.2.3-设置API Key秘钥

    使用下面命令进行设置Nuget的API Key(将my_api_key参数替换成自己生成的APIKey)

    nuget setApiKey my_api_key

    成功截图:
    image.png


    3.2.4-生成nuspec文件

    使用【nuget spec】命令生产.nuspec 文件,文件xml格式的。

    命令:nuget spec

    成功截图:
    image.png


    3.2.5-生成nupkg文件

    使用【nuget pack】命令生成.nupkg文件。

    命令:nuget pack

    成功截图:
    image.png


    3.2.6-上传到nuget服务器

    输入以下命令,可以将.nupkg包上传发布到NuGet服务器上(将my_api_key参数替换成自己生成的APIKey)。

    命令:nuget push Kimi.RocketMQ.NET.1.0.0.nupkg my_api_key -Source https://api.nuget.org/v3/index.json

    上传成功后的邮件:
    image.png
    上传成功后,需要等待10几分钟。官方需要先审核,审核通过后还需要进行重新索引,然后还需要同步。等待10多分钟后,就可以搜索到上传的包了。
    image.png


    四、NuGet包的管理

    4.1-删除NuGet包

    NuGet包无法删除,但是隐藏对应的版本。
    image.png
    选择要隐藏的版本后,然后取消勾选【List in search results】,然后点击【Save】保存即可。
    image.png
    效果(隐藏后就搜索不到1.0.0的版本了):image.png


    五、防踩坑指南

    5.1-响应状态代码不指示成功: 403

    详细错误:

    响应状态代码不指示成功: 403 (The specified API key is invalid, has expired, or does not have permission to access the specified package.)。

    解决方案:提示秘钥Key无效或者过期了,可以去后台重新生成一个,按照【1.2】步骤操作。


    5.2-This package has not been indexed yet

    详细错误:

    This package has not been indexed yet. It will appear in search results and will be available for install/restore after indexing is complete.

    错误截图:
    image.png
    解决方案:错误提示说"此程序包尚未编制索引。它将出现在搜索结果中,并可在索引完成后进行安装/还原"。所以需要等10分钟左右就行了,等程序包编制好索引就可以在NuGet客户端搜索到了。


    5.3-在以下主源中找不到包“Kimi.RocketMQ.NET 1.0.5”

    详细错误:

    在以下主源中找不到包“Kimi.RocketMQ.NET 1.0.5”:“https://api.nuget.org/v3/index.json”。请验证你的所有联机包源是否都可用,以及是否正确指定了包 ID、版本。

    解决方案:等待10分钟左右就能找到了。因为上传成功后需要进行编制索引、同步等操作。


    5.4-响应状态代码不指示成功: 409

    详细错误:

    响应状态代码不指示成功: 409 (A package with ID 'Kimi.RocketMQ.NET' and version '1.0.5' already exists and cannot be modified.)。

    错误截图:
    image.png
    解决方案:说明这个【1.0.9】的版本已经存在了,修改版本号重新发布即可。



    原文链接:https://www.cnblogs.com/kimiliucn/p/17675287.html


    __EOF__

  • 本文作者: 西瓜程序猿
  • 本文链接: https://www.cnblogs.com/kimiliucn/p/17675287.html
  • 关于博主: 评论和私信会在第一时间回复。或者直接私信我。
  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
  • 声援博主: 如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。
  • 相关阅读:
    SpringBoot交友APP项目实战(详细介绍+案例源码) - 9.小视频(SpringCache缓存)
    基于元数据的数据治理分析功能说明
    2.1Java内存模型之JMM内存模型规范详解
    Mysql进阶优化篇03——多表查询的优化
    设计模式-单例模式
    go学习笔记
    【1++的C++进阶】之emplace详解
    Redis的使用(四)常见使用场景-缓存使用技巧
    【endnote】如何将参考文献放到想放的位置
    五、Kafka日志存储
  • 原文地址:https://www.cnblogs.com/kimiliucn/p/17675287.html