这样入门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架构的项目,主要还是 ...
随机推荐
- Oracle E-Business Suite Release 12.2 Information Center - Manage
Oracle E-Business Suite Maintenance Guide Release 12.2 Part No. E22954-14 PDF: http://docs.oracl ...
- TCP连接建立系列 — TCP选项解析
本文主要分析:在收到客户端的SYN包时,服务器端是如何解析它所携带的TCP选项,并结合本端情况决定是否予以支持. 内核版本:3.6 Author:zhangskd @ csdn blog 概述 收到客 ...
- solr研磨之游标分页
普通分页 当需要深度分页的时候,比如查询第10000页数据,每页显示10条,意味着需要提取前10000 x 10 页的数据,并将这100000条数据缓存在内存中,然后在内存中进行排序.最后返回最后10 ...
- CoolBlog开发笔记第5课:请求与响应
教程目录 1.1 CoolBlog开发笔记第1课:项目分析 1.2 CoolBlog开发笔记第2课:搭建开发环境 1.3 CoolBlog开发笔记第3课:创建Django应用 1.4 CoolBlog ...
- iframe之局部刷新
例如: <iframe src="1.htm" name="ifrmname" id="ifrmid"></ifram ...
- Dubbo入门—搭建一个最简单的Demo框架
一.Dubbo背景和简介 1.电商系统的演进 Dubbo开始于电商系统,因此在这里先从电商系统的演变讲起. a.单一应用框架(ORM) 当网站流量很小时,只需一个应用,将所有功能如下单支付等都部署在一 ...
- 没人看系列-----html随笔
<!DOCTYPE> 目录 没人看系列-----html/css详解 前言 不多说这段时间写了好多好多前端的东西,以至于自己重新返回看了一遍前端的所有技术.故此做个总结,准备学东西的请绕行 ...
- Vue、AngularJS 双向数据绑定解剖
数据与视图的绑定与同步,最终体现在对数据的读写处理过程中,也就是 Object.defineProperty() 定义的数据 set.get 函数中.Vue 中对于的函数为 defineReactiv ...
- 在网页中使用particlesjs实现背景的动态粒子特效
先上一张效果图: 这种动态的背景特效,制作起来其实非常简单. 使用了particles.js particles.js可以从github网站下载到最新的源码,网址是 https://github.co ...
- Windows下的OpenCVSharp配置
OPenCvSharp是OpenCV的Net Warpper,应用最新的OpenCV库开发,目前放在github.. 本人认为OpenCvSharp比EmguCV使用起来更为方便,因为函数更接近于原生 ...