为什么 web 开发人员需要迁移到. NET Core, 并使用 ASP.NET Core MVC 构建 web 和 webservice/API - 张善友 - 博客园
2018 .NET开发者调查报告: .NET Core 是怎么样的状态,这里我们看到了还有非常多的.net开发人员还在观望,本文给大家一个建议。这仅代表我的个人意见, 我有充分的理由推荐.net 程序员使用 . net core而不是 . net Framework。有些人可能不同意我的观点, 但是分享想法和讨论它是好的。.net 程序员或他们所在的团队总有各种理由说他们的系统还在使用旧系统, 这显然是企业开发人员的事情。所以, 我将列出一些关于谁应该迁移到使用. net core而不是. net 框架。以下是我的想法:
- 如果您是 旧式Windows 服务、web 应用程序或 web 服务的维护者, 则您需要继续使用. NET 框架。
- 如果您的应用程序将部署在旧的 Windows 服务器上,比如windows 2003/xp, 您需要继续使用. NET 框架。
- 如果您确信您的系统近期不会部署到云中, 那么您现在就可以继续使用. NET 框架。
- 如果您对使用. net 框架没有任何选择,比如来自公司的要求, 您需要继续使用. net 框架,这种情况对你的发展是不利的,我劝你学习.net core, 换家更有追求的公司。
初学者, 只学习. NET Core!
如果你是一个初学者开始学习 ASP.NET 或 ASP.NET MVC, 你可能并不知道什么是. net Framework和. net ore。不用担心!我建议您看下官方文档 https://docs.microsoft.com/zh-cn/aspnet/index, 您可以轻松地看到比较和差异。下面是我可以分享的一些. net framework和. net core的部分, 您可以点击每个链接以获取开发的工具。
.NET Framework | .NET Core | |
Technology | First Release 2002 (Mature) | First Release 2016 (Mature) |
Latest Version | 4.7.2 ( Reference Source) | 2.0.6 ( Open Source Software) SDK Version 2.1.3 |
SDK | WindowsOnly (Version 7, 8, 10) | Windows(Version 7, 8, 10), Linux(redhat, Ubuntu >14.04, Fedora, Debian, CentOS 7, openSUSE 24, Oracle Linux 7, SLES 12), Mac |
ASP.NET Performance | 57,843 Request/Seconds (Plain Text) | 1,822,366 Request/Seconds (Plain Text) Here is some real world news as reference: ASP.NET Core – 2300% More Requests Served Per Second. |
Best IDE/Editor | Visual Studio 2017 Community(latest, FREE) | Visual Studio 2017 Community(latest, FREE), Visual Studio Codefor Windows, Linux and Mac (FREE), Visual Studio for Mac Community(FREE) |
Web Framework | Web Form, ASP, MVC ( Weband Web API) | MVC Core ( Web, Razor Page, Web API) |
Entity Framework (ORM) | Entity Framework 6.2 (latest) (Microsoft SQL Server, Oracle, MySQL (Official), PostgreSL, SQLite, IBM Data Server (DB2)) | Entity Framework Core 2.0.1 (latest) (InMemory (for Testing), Microsoft SQL Server, SQLite, PostgreSQL (Npgsql), IBM Data Server (DB2), MySQL (Official), MySQL (Pomelo), Microsoft SQL Server Compact Edition, Devart (MySQL, Oracle, PostgreSQL, SQLite, DB2, and more), Oracle (not yet available), MyCat, Firebird-Community) |
Frontend | Plain MVC, Angular (mostly using MVC) | Plain MVC, Angular, React, and Redux |
只需要5分钟入门使用. NET Core
如果您在移动笔记本上看这篇文章, 请下载并安装当前操作系统 (Windows、Linux、Mac) 的 . NET Core SDK。您不需要安装 Visual Studio 2017 就可以使用命令行开发. NET Core应用。你完成安装 SDK 后, 打开 Shell或 PowerShell(在 Windows 中)、 终端(在 Linux 或 Mac 中), 输入以下命令:
dotnet new console -o myApp
cd myApp
dotnet run
恭喜您, 你已经使用. NET Core 创建了第一个控制台应用程序。现在, 您可以通过将此应用程序发布到所需的任何平台来部署。在 Mac 机上,
dotnet publish --runtime osx-x64
或者安卓,
dotnet publish --runtime Android
下面是 runtime identifier catalog的完整列表。那么, 这个命令实际上做了什么:
dotnet new console -o myApp
当我们运行这个命令时, 它实际上是在文件夹中创建一个 控制台应用程序项目
myApp
。如果您查看文件夹
myApp
, 则应该看到以下文件
myApp.csproj
Program.cs
文件本身只是一个简单的Hello world。 Program.cs
using System;
namespace myApp
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Hello World!");
}
}
}
如果执行此命令,
dotnet new --list
它将从框中列出可用模板。这是你可能会看到的,
如果用mvc替换console时, 它将创建一个使用 ASP.NET core MVC的 web 应用程序项目。
迁移到 ASP.NET Core 意味着迁移到现代 Web 应用程序
我可以转移到 ASP.NET Core吗?简单的回答当然是 否, 您不能仅仅是使用 Visual Studio 2017 打开旧的 ASP.NET Web Form或 mvc 5就可以完成转换到 ASP.NET Core mvc。你可以参考以下老代码迁移策略:
- 如果你的的 web 应用程序使用 web form, 则不能直接将其转换或迁移到 ASP.NET Core。 因为 Web form和 MVC 有着完全不同的体系结构模型。MVC 使用模型、视图和控制器的分离。也没有 webform 控件组件 (如 web 窗体)。ASP.NETCore MVC 使用纯 HTML5 元素。当然您可以使用 TagHelpers来创建自定义 HTML 属性, 这些特性将转换为普通 HTML5。
- 如果你的 web 应用程序使用的是 ASP.NET MVC 5, 则你可以首先创建一个新的 ASP.NET Core MVC 项目, 复制粘贴某些代码到 ASP.NET Core。这将需要一些调整, 特别是在RazorPage。
- 如果你的 web 应用程序只是一个 web api , 则你可以首先创建一个新的 ASP.NET Core Web API项目,不是简单复制一些代码。这里需要做些调整, 因为 ASP.NET Core web api 使用的是 web api 2。
- 使用 HTML5! HTML5 仅用于现代 web 应用程序标准。使用来自 W3C(万维网 联合体) 标准的 HTML5。而不仅仅是来自 Microsoft Edge、 Chrome、 Firefox等的标准。因为每个浏览器都有自己的功能, 称为 平台标准, 而某些浏览器平台功能不成为 W3C 标准。如果只使用 chrome 功能标准, 则 web 可能只会被 chrome 绑定, 并且无法在其他浏览器上打开。并非所有浏览器都支持其他浏览器功能。
- 响应式布局,响应式布局,响应式布局! 重要的事情要说三遍。我们时常听到开发者说, " 不, 我们不需要响应式布局, 这只是桌面浏览器, 我们只是让它静态布局"。如果你的网站to c的, 你必须做响应式布局, 因为现在移动时代,更多的用户将使用他们的ios/android上面的移动浏览器查看。
- 不要在开发项目中直接使用 CSS。使用 SASS或者 LESS.。您可以使用 ASP.NET Core轻松完成此项任务。您甚至可以添加Gulp、Grunt或者webpack来编译 CSS。
如果您的代码遵循 S.O.L.I.D Principle原则进行正确的开发, 我相信, 迁移工作应该是很容易的, 而不是太多的调整。但是, 如果您的代码是意大利面条,则需要进行重构,.NET Core默认就使用依赖关系注入。这是ASP.NET常见最佳实践,当然是现在做更好, 而不是不做。好处也很多, 你可以学到一些新的东西, 您的新 web 应用程序将具有更好的性能, 更加现代化和可维护性。
对老板说:迁移到. NET Core
我知道你的老板会回答什么, 是的, 那 恐怖语句 " 兼容吗?"
我的建议是说: " 是的, 它是兼容的! 他们都是. NET。但我们需要一些调整, 一些需要小的编码更改,以符合编程的最佳实践"
我们需要迁移到.NET Core的精神是, 如果不是现在, 那么何时?现在马上就有发布.NET Core 2.1, 一切都改变了。技术发生了变化 ( 现代 Web 应用程序、移动、增强现实等)、基础结构已更改 ( 云、AI)、开发体系结构也已更改 ( 容器、无服务器) 等。
咱们这行业不尊重传统,只尊重创新. --- 微软CEO Satya Nadella
没那么容易
答案是肯定的。但是, 并不意味着不可能。它需要勇气和知识。 愿. NET 力量与您同在!