本文章主要说明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,如何的更多相关文章

  1. .NET Core实战项目之CMS 第二章 入门篇-快速入门ASP.NET Core看这篇就够了

    作者:依乐祝 原文链接:https://www.cnblogs.com/yilezhu/p/9985451.html 本来这篇只是想简单介绍下ASP.NET Core MVC项目的(毕竟要照顾到很多新 ...

  2. 基于 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 时代,包括其插件在需要时就引 ...

  3. 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 ...

  4. 这样入门asp.net core 之 静态文件

    本文章主要说明asp.net core中静态资源处理方案: 一.静态文件服务 首先明确contentRoot和webroot这两个概念 contentRoot:web的项目文件夹,其中包含webroo ...

  5. 菜鸟入门【ASP.NET Core】5:命令行配置、Json文件配置、Bind读取配置到C#实例、在Core Mvc中使用Options

      命令行配置 我们通过vs2017创建一个控制台项目CommandLineSample 可以看到现在项目以来的是dotnet core framework 我们需要吧asp.net core引用进来 ...

  6. 观看杨老师(杨旭)Asp.Net Core MVC入门教程记录

    观看杨老师(杨旭)Asp.Net Core MVC入门教程记录 ASP.NET Core MVC入门 Asp.Net Core启动和配置 Program类,Main方法 Startup类 依赖注入,I ...

  7. 《ASP.NET Core项目开发实战入门》带你走进ASP.NET Core开发

    <ASP.NET Core项目开发实战入门>从基础到实际项目开发部署带你走进ASP.NET Core开发. ASP.NET Core项目开发实战入门是基于ASP.NET Core 3.1 ...

  8. ASP.NET Core 中文文档 第二章 指南(3)用 Visual Studio 发布一个 Azure 云 Web 应用程序

    原文:Getting Started 作者:Rick Anderson 翻译:谢炀(Kiler) 校对:孟帅洋(书缘).刘怡(AlexLEWIS).何镇汐 设置开发环境 安装最新版本的 Azure S ...

  9. ASP.NET Core 2.0 MVC项目实战

    一.前言 毕业后入职现在的公司快有一个月了,公司主要的产品用的是C/S架构,再加上自己现在还在学习维护很老的delphi项目,还是有很多不情愿的.之前实习时主要是做.NET的B/S架构的项目,主要还是 ...

随机推荐

  1. FNDCPASS Troubleshooting Guide For Login and Changing Applications Passwords

    In this Document   Goal   Solution   1. Error Starting Application Services After Changing APPS Pass ...

  2. C语言实现某年某月某日是某年的第几天

    看到这个标题,想实现这样的功能其实挺简单的,用C语言的switch语句加上闰年,平年条件的判断,再加上一定的逻辑可以轻松实现这样的函数,在linux内核中,存在判断闰年平年的接口,我将它移植出来后,写 ...

  3. 从开发者角度解析 Android N 新特性!

    大清早看到 Google 官方博客发布 Android N 的开发者预览版,立马从床上跳起来开始仔仔细细的读起来. 从开发者角度来看,Android N 的更新并不算大.网上之前流传的一些 Andro ...

  4. Loader转换器

    一.简介 webpack本身只能处理js模块,Loader可以理解为模块和资源的转换器,它本身是一个函数,接受文件作为参数,返回转换的结果.因此,我们就能通过require来加载任何类型的模块和文件. ...

  5. 9.3.3 scrapy 框架

    scrapy是一个非常好用的Web爬虫框架,非常适合抓取Web站点从网页中提取结构化的数据,并且支持自定义的需求.在使用scrapy爬取网页数据时,除了熟悉HTML标签,还需要了解目标网页的数据组织结 ...

  6. angular中的jqLite的基本使用方法

    angular.element() 参数要求是HTML string or DOMElement, angular.element 虽然很接近 jQuery,但是直接通过 HTML tag 去获取元素 ...

  7. angularjs指令中的compile与link函数详解

    这篇文章主要介绍了angularjs指令中的compile与link函数详解,本文同时诉大家complie,pre-link,post-link的用法与区别等内容,需要的朋友可以参考下   通常大家在 ...

  8. js正则表达式中test,exec,match方法的区别说明

    js正则表达式中test,exec,match方法的区别说明 test test 返回 Boolean,查找对应的字符串中是否存在模式.var str = "1a1b1c";var ...

  9. oracle的for和i++

    很长时间没用oracle的储存了,这次用到一次i++i++的sql语句:declarei_1 number(30) :=0;begin i_1 :=i_1+1;//i_1=1 insert into ...

  10. java并发编程——通过ReentrantLock,Condition实现银行存取款

         java.util.concurrent.locks包为锁和等待条件提供一个框架的接口和类,它不同于内置同步和监视器.该框架允许更灵活地使用锁和条件,但以更难用的语法为代价. Lock 接口 ...