72 lines
4.4 KiB
Markdown
72 lines
4.4 KiB
Markdown
---
|
|
title: Introduction to ASP.NET Core
|
|
author: rick-anderson
|
|
description: Get an introduction to ASP.NET Core, a cross-platform, high-performance, open-source framework for building modern, cloud-based, Internet-connected applications.
|
|
ms.author: riande
|
|
ms.date: 9/28/2018
|
|
uid: index
|
|
---
|
|
# Introduction to ASP.NET Core
|
|
|
|
By [Daniel Roth](https://github.com/danroth27), [Rick Anderson](https://twitter.com/RickAndMSFT), and [Shaun Luttin](https://twitter.com/dicshaunary)
|
|
|
|
ASP.NET Core is a cross-platform, high-performance, [open-source](https://github.com/aspnet/home) framework for building modern, cloud-based, Internet-connected applications. With ASP.NET Core, you can:
|
|
|
|
* Build web apps and services, [IoT](https://www.microsoft.com/internet-of-things/) apps, and mobile backends.
|
|
* Use your favorite development tools on Windows, macOS, and Linux.
|
|
* Deploy to the cloud or on-premises.
|
|
* Run on [.NET Core or .NET Framework](https://docs.microsoft.com/dotnet/articles/standard/choosing-core-framework-server).
|
|
|
|
## Why use ASP.NET Core?
|
|
|
|
Millions of developers have used (and continue to use) [ASP.NET 4.x](https://docs.microsoft.com/aspnet/overview) to create web apps. ASP.NET Core is a redesign of ASP.NET 4.x, with architectural changes that result in a leaner, more modular framework.
|
|
|
|
[!INCLUDE[](~/includes/benefits.md)]
|
|
|
|
## Build web APIs and web UI using ASP.NET Core MVC
|
|
|
|
ASP.NET Core MVC provides features to build [web APIs](xref:tutorials/index#build-web-apis) and [web apps](xref:tutorials/index#build-web-apps):
|
|
|
|
* The [Model-View-Controller (MVC) pattern](xref:mvc/overview) helps make your web APIs and web apps [testable](xref:test/index).
|
|
* [Razor Pages](xref:razor-pages/index) (new in ASP.NET Core 2.0) is a page-based programming model that makes building web UI easier and more productive.
|
|
* [Razor markup](xref:mvc/views/razor) provides a productive syntax for [Razor Pages](xref:razor-pages/index) and [MVC views](xref:mvc/views/overview).
|
|
* [Tag Helpers](xref:mvc/views/tag-helpers/intro) enable server-side code to participate in creating and rendering HTML elements in Razor files.
|
|
* Built-in support for [multiple data formats and content negotiation](xref:web-api/advanced/formatting) lets your web APIs reach a broad range of clients, including browsers and mobile devices.
|
|
* [Model binding](xref:mvc/models/model-binding) automatically maps data from HTTP requests to action method parameters.
|
|
* [Model validation](xref:mvc/models/validation) automatically performs client-side and server-side validation.
|
|
|
|
## Client-side development
|
|
|
|
ASP.NET Core integrates seamlessly with popular client-side frameworks and libraries, including [Angular](xref:spa/angular), [React](xref:spa/react), and [Bootstrap](https://getbootstrap.com/). For more information, see [Client-side development](xref:client-side/index).
|
|
|
|
<a name="target-framework"></a>
|
|
|
|
## ASP.NET Core targeting .NET Framework
|
|
|
|
ASP.NET Core can target .NET Core or .NET Framework. ASP.NET Core apps targeting .NET Framework aren't cross-platform—they run on Windows only. There are no plans to remove support for targeting .NET Framework in ASP.NET Core. Generally, ASP.NET Core is made up of [.NET Standard](/dotnet/standard/net-standard) libraries. Apps written with .NET Standard 2.0 run anywhere that .NET Standard 2.0 is supported.
|
|
|
|
ASP.NET Core 2.x is supported on .NET Framework versions compatible with .NET Standard 2.0:
|
|
|
|
* .NET Framework 4.7.1 and later is strongly recommended.
|
|
* .NET Framework 4.6.1 and later.
|
|
|
|
There are several advantages to targeting .NET Core, and these advantages increase with each release. Some advantages of .NET Core over .NET Framework include:
|
|
|
|
* Cross-platform. Runs on macOS, Linux, and Windows.
|
|
* Improved performance
|
|
* Side-by-side versioning
|
|
* New APIs
|
|
* Open source
|
|
|
|
We're working hard to close the API gap from .NET Framework to .NET Core. The [Windows Compatibility Pack](/dotnet/core/porting/windows-compat-pack) made thousands of Windows-only APIs available in .NET Core. These APIs weren't available in .NET Core 1.x.
|
|
|
|
## Next steps
|
|
|
|
For more information, see the following resources:
|
|
|
|
* [Get started with Razor Pages](xref:tutorials/razor-pages/razor-pages-start)
|
|
* [ASP.NET Core tutorials](xref:tutorials/index)
|
|
* <xref:tutorials/publish-to-azure-webapp-using-vs>
|
|
* [ASP.NET Core fundamentals](xref:fundamentals/index)
|
|
* [The weekly ASP.NET community standup](https://live.asp.net/) covers the team's progress and plans. It features new blogs and third-party software.
|