温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

从ASP.NET Core2.2到3.0你会遇到什么问题

发布时间:2021-08-05 09:54:29 来源:亿速云 阅读:131 作者:小新 栏目:开发技术

这篇文章主要介绍了从ASP.NET Core2.2到3.0你会遇到什么问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

我遇到的问题

ASP.NET Core2.0时代,若要为项目添加 EF Core 支持,需要安装相应的数据库驱动包。 教程中使用 SQL Server,相关驱动包Microsoft.EntityFrameworkCore.SqlServer。 此包包含在 Microsoft.AspNetCore.App 元包中,因此,如果应用具有对 Microsoft.AspNetCore.App 包的包引用,则无需引用该包。而2.0中的模板项目会自动为我们加载Mcrosoft.AspNetCore.App这个包的。但是3.0中没有了这个Mcrosoft.AspNetCore.App这个包,模块化的更彻底了!所需要的EF相关的包需要你自己来进行引用。

2.0升3.0升级指南

就着今天遇到的问题,所以我整理下ASP.NET Core从2.0升级3.0的一个升级指南,希望对大伙有所帮助,当然大伙也可以直接阅读微软的官方文档进行查看。但是我在阅读官方说明的时候,总感觉翻译的不是很准确,读起来很拗口,所以这里我是自己的理解对官方文档的一个补充。

更新项目文件

设置TargetFramework到netcoreapp3.0:

<TargetFramework>netcoreapp3.0</TargetFramework>

删除Microsoft.AspNetCore.All或Microsoft.AspNetCore.App元包的任何<PackageReference>。

将<PackageReference>元素中剩余的Microsoft.AspNetCore.*程序包更新到当前的预览版中 (例如,3.0.0-preview3.19128.7)。

如果没有对应的 3.0 版本的包,则说明包可能会在 3.0 中弃用。 其中许多之前都属于Microsoft.AspNetCore.App并且不需要单独引用的包,如上面我遇到的问题,关于SQL Server的EF相关的包。 具体的不再在 3.0 中生成的包的列表,请参阅aspnet/AspNetCore #3756。

某些程序集已从2.x和3.0之间的Microsoft.aspnetcore.app中删除。如果您正在使用aspnet/AspNetCore #3755中列出的包中的API,则可能需要单独添加到。

例如,Microsoft.EntityFrameworkCore和System.Data.SqlClient不再属于Microsoft.AspNetCore.App得一部分。 Microsoft.aspnetcore.app中的程序集列表尚未定稿,将在3.0 RTM之前更改。

添加Json.NET 支持。

项目默认为 ASP.NET Core 3.0 或更高版本设置为进程内承载模型。 当然,如果其值为InProcess您还可以通过删除<AspNetCoreHostingModel>元素,来进行修改。

作为提高ASP.NET Core 共享的框架工作的一部分,Json.NET已从 ASP.NET Core 共享框架中删除。

若要在 ASP.NET Core 3.0 项目中使用 Json.NET:

添加到包引用Microsoft.AspNetCore.Mvc.NewtonsoftJson

更新ConfigureServices调用AddNewtonsoftJson()。

services.AddMvc()
 .AddNewtonsoftJson();

Newtonsoft 的个性化设置可以设置为AddNewtonsoftJson:

services.AddMvc()
 .AddNewtonsoftJson(options =>
   options.SerializerSettings.ContractResolver =
    new CamelCasePropertyNamesContractResolver());

HostBuilder 替换 WebHostBuilder

使用 ASP.NET Core 3.0 模板泛型宿主。 早期版本使用Web 主机。 下面的代码显示了生成 ASP.NET Core 3.0 模板Program类:

public class Program
{
 public static void Main(string[] args)
 {
  CreateHostBuilder(args).Build().Run();
 }

 public static IHostBuilder CreateHostBuilder(string[] args) =>
  Host.CreateDefaultBuilder(args)
   .ConfigureWebHostDefaults(webBuilder =>
   {
    webBuilder.UseStartup<Startup>();
   });
}

下面的代码演示模板生成 ASP.NET Core 2.2Program类:

public class Program
{
 public static void Main(string[] args)
 {
  CreateWebHostBuilder(args).Build().Run();
 }

 public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
  WebHost.CreateDefaultBuilder(args)
   .UseStartup<Startup>();
}

IWebHostBuilder 将保留在 3.0,是一种webBuilder上面的代码示例所示。 WebHostBuilder 将在未来版本中弃用并替换为HostBuilder。

从WebHostBuilder到HostBuilder最显著的变化是依赖关系注入 (DI)。 使用时HostBuilder,只能将IConfiguration并IHostingEnvironment注入到Startup的构造函数中。 HostBuilder DI 约束:

  1. 使DI容器只能构建一次。

  2. 避免产生的对象生存期问题,例如解决多个单例实例。

更新 SignalR 代码

如果您调用AddJsonProtocol,将其替换为AddNewtonsoftJsonProtocol。

以下示例显示更改前后的服务器代码:

services.AddSignalR(...)
  .AddJsonProtocol(...) // 2.2
services.AddSignalR(...)
  .AddNewtonsoftJsonProtocol(...) // 3.0

以下示例显示更改前后的.NET客户端代码:

connection = new HubConnectionBuilder()
 .WithUrl(...)
 .AddJsonProtocol(...) // 2.2
 .Build()
connection = new HubConnectionBuilder()
 .WithUrl(...)
 .AddNewtonsoftJsonProtocol(...) // 3.0
 .Build()

选择启用运行时编译

在 3.0 中,运行时编译是可选的方案。 若要启用运行时编译,请参阅ASP.NET Core 中的 Razor 文件编译。

总结

感觉微软在努力实现ASP.NET Core的模块化,减小各种依赖,让包变得更小。同时ASP.NET Core也已经很完善了,大伙是时候用起来ASP.NET Core了。另外需要说明的一点是,大伙如果是为了体验ASP.NET Core3.0的话,现在就可以,如果是用在生产环境的话最好还是等待正式版的发布吧。

感谢你能够认真阅读完这篇文章,希望小编分享的“从ASP.NET Core2.2到3.0你会遇到什么问题”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI