.net core 一次坑爹的类库打包过程
众所周知,.net core 跨平台类库引用一定要通过nuget获得。(如有问题,欢迎指出)
打包
将普通.net project转换成.net core 的类库有两种方式:
1.新建.net core 的类库 -》 把原所有文件拷贝过来 -》 在project.json中解决依赖包问题 -》编译打包
2.新建.net core 的类库 -》 在project.json中配置源文件include complie, 如下:
"frameworks": {
"netstandard1.6": {
"imports": "dnxcore50",
"buildOptions": {
"compile": {
"include": [ "../MongoDB.Driver/**/*.cs", "../MongoDB.Shared/Hasher.cs" ]
},
"define": [ "DEBUG", "TRACE" ],
"warningsAsErrors": true,
"outputName" : "MongoDB.Driver",
"xmlDoc": true
}
}
}
通过buildOptions的comple的include,把原来文件路径引用过来
-》 编译project, 通过cmd命令切换到project目录
-> dotnet build
-》 打成nuget包
-> dotnet pack
这样,在原bin/debug目录下面会多出nuget包文件。
引用
坑爹就坑在引用上。
通过反复验证,一个package包无论引用了多少其他程序集(包括自定义的),只需发布最终需要的package就可以了,因为依赖关系都已经在里面了。如下图:

我的MongoDB.Driver.Dotnet引用了MongoDB.Bson.Dotnet和MongoDB.Driver.Core.Dotnet,打包的时间只需MongoDB.Driver.Dotnet就可以了。
依赖关系都在打包的MongoDB.Driver.Dotnet.nuspec文件里
<?xml version="1.0" encoding="utf-8"?>
<package xmlns="http://schemas.microsoft.com/packaging/2012/06/nuspec.xsd">
<metadata>
<id>MongoDB.Driver.Dotnet</id>
<version>1.0.0</version>
<authors>MongoDB.Driver.Dotnet</authors>
<owners>MongoDB.Driver.Dotnet</owners>
<requireLicenseAcceptance>false</requireLicenseAcceptance>
<description>MongoDB.Driver.Dotnet</description>
<tags></tags>
<dependencies>
<group targetFramework=".NETStandard1.6">
<dependency id="MongoDB.Bson.Dotnet" version="[1.0.0, )" />
<dependency id="MongoDB.Driver.Core.Dotnet" version="[1.0.0, )" />
<dependency id="NETStandard.Library" version="[1.6.0, )" />
<dependency id="System.Linq.Expressions" version="[4.1.0, )" />
<dependency id="System.Linq.Queryable" version="[4.0.1, )" />
</group>
</dependencies>
</metadata>
</package>
但这不是坑爹的地方,坑就坑在nuget在本地会有缓存在以下目录中
C:\Users\%Local User%\.nuget\packages
如果重新打包没有升级版本号,单纯在服务器端切换nuget包是没有的,一定要把本地也清空了。。
目测是2015升级到最新版本才有的问题,因为我之前服务器直接替换没遇到过这样类似的问题,stackoverflow的这位仁兄也是
http://stackoverflow.com/a/33214933
.net core 一次坑爹的类库打包过程的更多相关文章
- 【转】.net core 一次坑爹的类库打包过程
自己遇到这个问题,记录一下,原文链接:http://www.cnblogs.com/Hai--D/p/5776463.html. 众所周知,.net core 跨平台类库引用一定要通过nuget获得. ...
- 使用VS中自带的一键打包功能将我们的ASP.NET Core类库打包并将程序包(类库)发布到NuGet平台上进行管理
本章将和大家简单分享下如何使用VS中自带的一键打包功能将我们的ASP.NET Core类库打包并将程序包(类库)发布到NuGet平台上进行管理. 一.注册并登录NuGet平台 NuGet官网:http ...
- iOS 静态类库 打包 C,C++文件及和OC混编
iOS 静态类库 编译 C,C++ 我们都知道,OC 原生支持C, 在 创建的 OC类的 .m 里面,可以直接编写C的代码: 同样 Xcode 也支持 OC ,C++的混编,此时,我们通常把OC创建的 ...
- Android 类库打包、发布方法
开发Android应用的时候,对于可用于多个应用的公用的部分,或是打算发布给第三方进行应用集成的部分,要把这部分打包成类库怎么做呢? Android应用使用ADT打包成apk,apk中包含了运行程序所 ...
- Azure KeyVault(四)另类在 .NET Core 上操作 Secrets 的类库方法-----Azure.Security.KeyVault.Secrets
一,引言 上一篇文章我们在 .Net Core Web 项目中添加了 "Microsoft.Azure.KeyVault" 的 Nuget 包操作 Azure KeyVault 的 ...
- Android应用程序(APK)的编译打包过程
(9878) (7) 现在很多人想对Android工程的编译和打包进行自动化,比如建立每日构建系统.自动生成发布文件等等.这些都需要我们对Android工程的编译和打包有一个深入的理解,至少要知道它的 ...
- 【转】android Apk打包过程概述_android是如何打包apk的
最近看了老罗分析android资源管理和apk打包流程的博客,参考其他一些资料,做了一下整理,脱离繁琐的打包细节和数据结构,从整体上概述了apk打包的整个流程. 流程概述: 1.打包资源文件,生成 ...
- Android系统的镜像文件的打包过程
在前面一篇文章中,我们分析了Android模块的编译过程.当Android系统的所有模块都编译好之后,我们就可以对编译出来的模块文件进行打包了.打包结果是获得一系列的镜像文件,例如system.img ...
- android Apk打包过程概述_android是如何打包apk的
流程概述:1.打包资源文件,生成R.java文件2.处理aidl文件,生成相应java 文件3.编译工程源代码,生成相应class 文件4.转换所有class文件,生成classes.dex文件5.打 ...
随机推荐
- Attempt to insert non-property list object 报错原因
NSUserDefault 支持的存储类型有:NSString. NSNumber.NSDate. NSArray.NSDictionary.BOOL.NSInteger.NSFloat等系统定义的数 ...
- 深入理解JavaScript的闭包特性如何给循环中的对象添加事件
初学者经常碰到的,即获取HTML元素集合,循环给元素添加事件.在事件响应函数中(event handler)获取对应的索引.但每次获取的都是最后一次循环的索引.原因是初学者并未理解JavaScript ...
- nginx File not found
出现 nginx File not found 错误 首先判断这个文件是否 真的存在 如果文件确实存在 那么应该是 php-fpm 路径有问题了 解决办法 1查看 php-fpm 的配置文件 我的 文 ...
- Java 理论与实践: 正确使用 Volatile 变量
Java 语言中的 volatile 变量可以被看作是一种 "程度较轻的 synchronized":与 synchronized 块相比,volatile 变量所需的编码较少,并 ...
- Dictionary摘抄
Dictionary,字典,键值对集合. 下面的代码示例创建一个空的带有字符串键的字符串 Dictionary,并使用 Add 方法添加一些元素.该示例演示在尝试添加重复的键时 Add 方法引发Arg ...
- ORA-12516:TNS:listener could not find available handler with matching protocol stack
应用程序连接测试数据库时报ORA-12516:TNS:listener could not find available handler with matching protocol stack 检查 ...
- SQL Server 查询树结构的表,查询一个节点的所有子节点
;with cte as ( select * from Associator where No = 'mc1007' union all select air.* from Associator a ...
- 【转】hive优化之--控制hive任务中的map数和reduce数
一. 控制hive任务中的map数: 1. 通常情况下,作业会通过input的目录产生一个或者多个map任务. 主要的决定因素有: input的文件总个数,input的文件大小,集群设置 ...
- windows系统快捷操作の基础篇
从网上汇总了一些windows系统上常用的快捷键,结合自己的使用经验,将平时使用电脑时最常用的快捷键记录在此.注意这里罗列的是平时最常用到的,其他的一般来说不怎么用到的并不在此列,如果想要完整列表,请 ...
- jmeter接口自动化集成
接口自动化集成 一.jmeter基础学习 1.博客 :http://www.cnblogs.com/fnng/category/345478.html 2.博客 http://www.cnblo ...