- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我想创建一个 NuGet 包,它可以同时显式地面向 .NET Framework 4.6.2 和 .Net Standard 1.5。这是来自 VS 2017 的缩写 .csproj 文件:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFrameworks>net462;netstandard1.5</TargetFrameworks>
...
</PropertyGroup>
</Project>
当我从我的本地 Windows 计算机执行 dotnet build 和 pack 命令时,NuGet 包的创建完全符合预期。
但是,当我尝试在 Linux 上执行相同的 dotnet 命令时,我收到以下错误:
/opt/dotnet/sdk/1.0.4/Microsoft.Common.CurrentVersion.targets(1111,5): error MSB3644: The reference assemblies for framework ".NETFramework,Version=v4.6.2" were not found. To resolve this, install the SDK or Targeting Pack for this framework version or retarget your application to a version of the framework for which you have the SDK or Targeting Pack installed. Note that assemblies will be resolved from the Global Assembly Cache (GAC) and will be used in place of reference assemblies. Therefore your assembly may not be correctly targeted for the framework you intend.
然后我突然意识到 Linux 机器上没有任何常规的 .NET Framework 程序集(更不用说 .用于“目标包”,但它仅适用于 Windows。
冒着听起来幼稚的风险,有人在 Linux 上成功构建了可以面向 .NET Framework 的 NuGet 包吗?
最佳答案
.NET CLI 的分发版不包含任何 .NET Framework 的引用程序集,因此其 MSBuild 版本无法解析所需的编译时 Assets 。这个场景是tracked on GitHub虽然并且在迁移到 MSBuild 之前已经工作(CLI 可以使用 mono 的引用程序集)。
虽然有一些替代方案可用于在非 Windows 机器上构建您的库:
<强>1。使用 mono 5+ 构建库。
这可能是最稳定的路径。
Mono 5 及更高版本包含构建 .NET Standar 和 .NET Core 应用程序所需的构建逻辑。在 linux 上,mono 的 msbuild 可能需要作为单独的包安装。所以不用下面常用的命令
dotnet restore
dotnet build
dotnet publish -c Release
您将使用 mono 的 msbuild 执行以下操作:
msbuild /t:Restore
msbuild
msbuild /t:Publish /p:Configuration=Release
单声道 < 5.2 的打包解决方法:
唯一的限制是单声道 (< 5.2) 无法生成开箱即用的 NuGet 包,但有一个 workaround involving using the NuGet.Build.Tasks.Pack
NuGet package在允许你做的项目中 msbuild /t:Pack /p:Configuration=Release
通过像这样修改项目文件(特别注意删除 Sdk="..."
元素上的 <Project>
属性):
<Project>
<PropertyGroup>
<NuGetBuildTasksPackTargets>junk-value-to-avoid-conflicts</NuGetBuildTasksPackTargets>
</PropertyGroup>
<Import Project="Sdk.props" Sdk="Microsoft.NET.Sdk" />
<!-- All your project's other content here -->
<ItemGroup>
<PackageReference Include="NuGet.Build.Tasks.Pack" Version="4.0.0" PrivateAssets="All" />
</ItemGroup>
<Import Project="Sdk.targets" Sdk="Microsoft.NET.Sdk" />
</Project>
<强>2。使用 .NET CLI 并告诉 MSBuild 使用 mono 的引用程序集。
为 net*
构建时目标框架,您可以设置 FrameworkPathOverride
属性既可以作为环境变量也可以作为 csproj 文件中的属性。它需要指向一组引用程序集——这里可以使用mono的引用程序集。但有些包含一个特殊文件(redist 列表),其中包含对 .NET CLI 中的 MSBuild 版本无法遵循的其他目录的引用。它确实适用于很多场景:
export FrameworkPathOverride=/usr/lib/mono/4.5/
dotnet build -f net45
这被使用并且documented by the F# team .
<强>3。使用包含引用程序集的 NuGet 包。
在某些 MyGet 源上,Microsoft 发布了包含引用程序集的 NuGet 包。尽管它们未发布或“官方”,因此此过程可能会在某个时间点失败。然而他们确实plan to investigate making this path official .
首先在您的解决方案目录中创建一个包含以下内容的 NuGet.Config 文件以添加提要:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<packageSources>
<add key="dotnet-core" value="https://dotnet.myget.org/F/dotnet-core/api/v3/index.json" />
</packageSources>
</configuration>
然后你可以添加一个项目组来添加PackageReference
到一个目标包和一个PropertyGroup
像这样设置引用程序集的路径:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFrameworks>netcoreapp1.1;net461</TargetFrameworks>
</PropertyGroup>
<PropertyGroup Condition=" '$(TargetFramework)' == 'net461' ">
<RuntimeIdentifier>win7-x64</RuntimeIdentifier>
<FrameworkPathOverride>$(NuGetPackageFolders)microsoft.targetingpack.netframework.v4.6.1\1.0.1\lib\net461\</FrameworkPathOverride>
</PropertyGroup>
<ItemGroup Condition=" '$(TargetFramework)' == 'net461' ">
<PackageReference Include="Microsoft.TargetingPack.NETFramework.v4.6.1" Version="1.0.1" ExcludeAssets="All" PrivateAssets="All" />
</ItemGroup>
</Project>
您可以更改 RuntimeIdentifier
对于不同的平台,如果您使用 native Assets (例如,为 linux 获取 .so
文件)或在构建库时将其完全删除。
关于.net - 在 Linux 上构建面向 .NET Framework 的 NuGet 包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44770702/
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!