这样入门asp.net core,如何
本文章主要说明asp.net core的创建和简单使用。
一、使用到的命令
- dotnet new :创建项目(解决方案,类库,单元测试等),如:
dotnet new web - dotnet add package 添加一个nuget的引用
- dotnet test:运行测试
- dotnet build:编译项目
- dotnet sln add:将项目添加到解决方案
- dotnet add reference:对此项目添加项目引用
二、建立空项目
- 在测试目录下运行
dotnet new web -n baseWeb,创建web项目,结果如下图所示: 
- 运行
dotnet run,即可运行此项目,此命令内部会执行dotnet build命令编译项目,然后运行,结果如下: 
说明:此命令是在sln(解决方案)文件所在目录运行的,所以增加了-p参数,用于指定启动指定的项目。
三、引入mvc
- 由于我们创建是一个空web项目,是没有mvc相关依赖包的,所以首先需要运行
dotnet add package Microsoft.AspNet.Mvc进行依赖包的安装 - 然后在StartUp类的ConfigureServices方法中添加如下代码:
public void ConfigureServices(IServiceCollection service){
service.AddMvc();
service.AddRouting();
}
上述添加此添加了Mvc,也添加了路由
- 配置路由,还是在StartUp类中,其方法为Configure添加如下代码:
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
} //添加的代码
app.UseMvc(routers=>{
routers.MapRoute("default", "{controller=Home}/{action=Index}/{id?}");
}); app.Run(async (context) =>
{
await context.Response.WriteAsync("Hello World!");
});
}
- 对controller和view的创建
在创建controller时,没有找到完全好的 命令创建方法,所以使用的是手动创建文件,然后继承Controller类实现;而view是可以通过dotnet new page实现的,但也可以使用手动创建。文件结果如下:
- 执行
dotnet run运行,然后网页访问对就的地址即可
四、更换依赖注入为autofac
aspnet core是自带了依赖注入功能的,就是StartUp类中ConfigureServices方法的IServiceCollection类型的形参。如果你想替换为autofac。请参考如下步骤
- 安装autofac,以及acutofac的扩展类
- Autofac
- Autofac.Extensions.DependencyInjection
- 更改StartUp类中的configureSeervices方法
public IServiceProvider ConfigureServices(IServiceCollection service){
service.AddMvc();
service.AddRouting();
var containerBuilder = new ContainerBuilder();
containerBuilder.Populate(service);
containerBuilder.RegisterType<Services.ProductService>().As<Services.IProductService>();
var container = containerBuilder.Build();
return new AutofacServiceProvider(container);
}
- 其中,我们更改了ConfigureServices方法的返回值,由void换成IServiceProvider;此返回为AutofacServiceProvider类的一个实例;在上述过程中,使用了continerBuilder.Populate方法将service(IServiceCollection的实例对象)注入到autofac中。
- 其中为了测试DI能力,我们创建一个IProductService的注入,并在Controller中使用,相关代码如下:
- IProductService
namespace baseWeb.Services
{
public interface IProductService
{
int Get(int id);
}
}
- ProductService
using System.Collections.Generic; namespace baseWeb.Services
{
public class ProductService:IProductService
{
List<int> ls = new List<int>(); public ProductService(){
for(var i=; i<; i++){
ls.Add(i+);
}
}
public int Get(int id){
return ls[id];
}
}
}
- HomeController
using System;
using System.Collections.Generic;
using Microsoft.AspNetCore.Mvc; namespace baseWeb.Controllers
{
public class HomeController:Controller
{
private Services.IProductService productService; public HomeController(Services.IProductService productService){
this.productService = productService;
} public IActionResult Index(int id){
ViewData["value"] = this.productService.Get(id);
return View();
}
}
}
- 运行结果如下:

五、加入单元测试
在实际开发中,经常需要用到单元测试。.net core的单元测试也是如此的 so easy, fallow me。
- 运行
dotnet new xunit -n baseWebTest,即可创建一个以xunit为测试框架的单元测试项目 - 运行
dotnet add package Moq,安装Moq模拟框架(此命令需要进入到baseWebTest项目文件夹后运行) - 运行
dotnet add reference ../baseWeb/baseWeb.csproj,将baseWeb项目引入到此项目中。 - 编写单元测试代码如下:
using System;
using Xunit;
using Moq;
using baseWeb.Controllers;
using baseWeb.Services;
using Microsoft.AspNetCore.Mvc; namespace basewebtest
{
public class DemoTest
{
[Fact]
public void Test1()
{
var productServiceMock = new Mock<IProductService>();
productServiceMock.Setup(service=>service.Get()).Returns((int id)=>{
return id+;
});
var _controller = new HomeController(productServiceMock.Object); var result = _controller.Index();
var objectResult = Assert.IsType<ViewResult>(result);
var destResult = Assert.IsAssignableFrom<int>(objectResult.ViewData["value"]);
Assert.Equal(, destResult);
}
}
}
- 运行
dotnet test -p ./baseWebtest/baseWebtest.csproj即可,看到如下结果: 
六、其他
- 如果你是使用vscode编写,那么测试项目是可以在编译器中进行运行和调试的

- 下载测试源码
这样入门asp.net core,如何的更多相关文章
- .NET Core实战项目之CMS 第二章 入门篇-快速入门ASP.NET Core看这篇就够了
作者:依乐祝 原文链接:https://www.cnblogs.com/yilezhu/p/9985451.html 本来这篇只是想简单介绍下ASP.NET Core MVC项目的(毕竟要照顾到很多新 ...
- 基于 Vue.js 之 iView UI 框架非工程化实践记要 使用 Newtonsoft.Json 操作 JSON 字符串 基于.net core实现项目自动编译、并生成nuget包 webpack + vue 在dev和production模式下的小小区别 这样入门asp.net core 之 静态文件 这样入门asp.net core,如何
基于 Vue.js 之 iView UI 框架非工程化实践记要 像我们平日里做惯了 Java 或者 .NET 这种后端程序员,对于前端的认识还常常停留在 jQuery 时代,包括其插件在需要时就引 ...
- net core体系-web应用程序-4asp.net core2.0 项目实战(CMS)-第二章 入门篇-快速入门ASP.NET Core看这篇就够了
.NET Core实战项目之CMS 第二章 入门篇-快速入门ASP.NET Core看这篇就够了 原文链接:https://www.cnblogs.com/yilezhu/p/9985451.ht ...
- 这样入门asp.net core 之 静态文件
本文章主要说明asp.net core中静态资源处理方案: 一.静态文件服务 首先明确contentRoot和webroot这两个概念 contentRoot:web的项目文件夹,其中包含webroo ...
- 菜鸟入门【ASP.NET Core】5:命令行配置、Json文件配置、Bind读取配置到C#实例、在Core Mvc中使用Options
命令行配置 我们通过vs2017创建一个控制台项目CommandLineSample 可以看到现在项目以来的是dotnet core framework 我们需要吧asp.net core引用进来 ...
- 观看杨老师(杨旭)Asp.Net Core MVC入门教程记录
观看杨老师(杨旭)Asp.Net Core MVC入门教程记录 ASP.NET Core MVC入门 Asp.Net Core启动和配置 Program类,Main方法 Startup类 依赖注入,I ...
- 《ASP.NET Core项目开发实战入门》带你走进ASP.NET Core开发
<ASP.NET Core项目开发实战入门>从基础到实际项目开发部署带你走进ASP.NET Core开发. ASP.NET Core项目开发实战入门是基于ASP.NET Core 3.1 ...
- ASP.NET Core 中文文档 第二章 指南(3)用 Visual Studio 发布一个 Azure 云 Web 应用程序
原文:Getting Started 作者:Rick Anderson 翻译:谢炀(Kiler) 校对:孟帅洋(书缘).刘怡(AlexLEWIS).何镇汐 设置开发环境 安装最新版本的 Azure S ...
- ASP.NET Core 2.0 MVC项目实战
一.前言 毕业后入职现在的公司快有一个月了,公司主要的产品用的是C/S架构,再加上自己现在还在学习维护很老的delphi项目,还是有很多不情愿的.之前实习时主要是做.NET的B/S架构的项目,主要还是 ...
随机推荐
- FNDCPASS Troubleshooting Guide For Login and Changing Applications Passwords
In this Document Goal Solution 1. Error Starting Application Services After Changing APPS Pass ...
- C语言实现某年某月某日是某年的第几天
看到这个标题,想实现这样的功能其实挺简单的,用C语言的switch语句加上闰年,平年条件的判断,再加上一定的逻辑可以轻松实现这样的函数,在linux内核中,存在判断闰年平年的接口,我将它移植出来后,写 ...
- 从开发者角度解析 Android N 新特性!
大清早看到 Google 官方博客发布 Android N 的开发者预览版,立马从床上跳起来开始仔仔细细的读起来. 从开发者角度来看,Android N 的更新并不算大.网上之前流传的一些 Andro ...
- Loader转换器
一.简介 webpack本身只能处理js模块,Loader可以理解为模块和资源的转换器,它本身是一个函数,接受文件作为参数,返回转换的结果.因此,我们就能通过require来加载任何类型的模块和文件. ...
- 9.3.3 scrapy 框架
scrapy是一个非常好用的Web爬虫框架,非常适合抓取Web站点从网页中提取结构化的数据,并且支持自定义的需求.在使用scrapy爬取网页数据时,除了熟悉HTML标签,还需要了解目标网页的数据组织结 ...
- angular中的jqLite的基本使用方法
angular.element() 参数要求是HTML string or DOMElement, angular.element 虽然很接近 jQuery,但是直接通过 HTML tag 去获取元素 ...
- angularjs指令中的compile与link函数详解
这篇文章主要介绍了angularjs指令中的compile与link函数详解,本文同时诉大家complie,pre-link,post-link的用法与区别等内容,需要的朋友可以参考下 通常大家在 ...
- js正则表达式中test,exec,match方法的区别说明
js正则表达式中test,exec,match方法的区别说明 test test 返回 Boolean,查找对应的字符串中是否存在模式.var str = "1a1b1c";var ...
- oracle的for和i++
很长时间没用oracle的储存了,这次用到一次i++i++的sql语句:declarei_1 number(30) :=0;begin i_1 :=i_1+1;//i_1=1 insert into ...
- java并发编程——通过ReentrantLock,Condition实现银行存取款
java.util.concurrent.locks包为锁和等待条件提供一个框架的接口和类,它不同于内置同步和监视器.该框架允许更灵活地使用锁和条件,但以更难用的语法为代价. Lock 接口 ...