从零开始搭建.NET Core 2.0 API(学习笔记一)

一、 VS 2017 新建一个项目 选择ASP.NET Core Web应用程序,再选择Web API,选择ASP.NET Core 2.0版本

二、 添加API帮助页面 API项目添加 NuGet NSwag.AspNetCore 引用, 然后在添加NSwag设置

运行项目 http://localhost:prot/swagger 即可打开帮助页。

public void Configure(IApplicationBuilder app, IHostingEnvironment env)

{
  if (env.IsDevelopment())
  {
    app.UseDeveloperExceptionPage();
    app.UseBrowserLink();
  }
  else
  {
    app.UseExceptionHandler("/Home/Error");
  }   app.UseStaticFiles(); app.UseSwaggerUi(typeof(Startup).GetTypeInfo().Assembly, settings =>
{
  settings.GeneratorSettings.DefaultPropertyNameHandling = PropertyNameHandling.CamelCase;
}); app.UseMvc(route =>
{
  route.MapRoute(name: "default", template: "{controller=Home}/{action=Get}/{id?}");
}); }

三、 Startup 类ConfigureServices方法中,添加配置中心初始化;配置中心统一管理配置,便于维护

public IServiceProvider ConfigureServices(IServiceCollection services)
{
ConfigHelper.Init(Configuration["ConfigZookeeperAddress"], Configuration["ConfigNodePath"]);
services.AddSingleton<ILogWrite, LogWrite>(); services.AddMvc(options =>
{
options.Filters.Add<AuthorizationFilter>();
options.Filters.Add<ExceptionFilter>();
options.Filters.Add<PerformanceLogFilter>();
}); var builder = new ContainerBuilder();//实例化 AutoFac 容器
builder.Populate(services); // TODO: 这里添加其他需要注入类的注册 ApplicationContainer = builder.Build();
return new AutofacServiceProvider(ApplicationContainer);
}

四、添加一个基础设置项目,添加一个日志接口 ILogWrite,一个记录日志实现类 LogWrite 在Startup 类ConfigureServices方法中添加日志 Ioc

因为日志拦截器和异常拦截器会用到日志记录需要注入 所以日志在AddMvc()前面添加,Autofac配置不能在 AddMvc前面,所以这里用.NET Core的Ioc容器,后面Autofac会接管容器。

services.AddSingleton<ILogWrite, LogWrite>();

五、filter 添加三个类分别是

  a AuthorizationFilter 权限过滤器

  b ExceptionFilter 异常过滤器

  c PerformanceLogFilter 性能日志过滤器

  ExceptionFilter 、PerformanceLogFilter 分别定义构造函数,注入日志依赖。

public ExceptionFilter(ILogWrite logWrite)
{
  _logWrite = logWrite;
} public PerformanceLogFilter(ILogWrite logWrite)
{
  _logWrite = logWrite;
}

过滤器必须添加在 Startup类ConfigureServices的services.AddMvc()中

services.AddMvc(options =>
{
options.Filters.Add<AuthorizationFilter>();
options.Filters.Add<ExceptionFilter>();
options.Filters.Add<PerformanceLogFilter>();
});

六、Action参数读取,为了在异常过滤器、性能日志过滤器中,读取参数需要在权限过滤器中添加下面两行代码

public class AuthorizationFilter : IAuthorizationFilter
{
  public void OnAuthorization(AuthorizationFilterContext context)
  {
    HttpRequest request = context.HttpContext.Request;
    request.EnableRewind();
    request.Body.Position = 0;
  }
}

七、性能日志过滤器 PerformanceLogFilter 继承 IActionFilter,实现两个接口

    OnActionExecuting 在调用操作方法之前发生
    OnActionExecuted 在调用操作方法之后发生
  a 在方法 OnActionExecuting中 实例化一个 Stopwatch 用于记录方法开支执行时间
    把Stopwatch 实力加入 HttpContext.Items 中,便于在 OnActionExecuted 获取。

  b 读取Action请求参数, 放入 HttpContext.Items 中, 不知道为什么OnActionExecuted 去不到参数

     /// <summary>
/// 在调用操作方法之前发生。
/// </summary>
/// <param name="context"></param>
public void OnActionExecuting(ActionExecutingContext context)
{
       //
if (SkipLogging(context)) return; var watch = new Stopwatch();
context.HttpContext.Items[ConfigHelper.HttpRequestStopWatcher] = watch;
var paramenters = context.ActionArguments.Count==0?string.Empty:context.ActionArguments.Serialize();
context.HttpContext.Items[ConfigHelper.FilterActionArguments] = paramenters;
watch.Start();
}

OnActionExecuting 中增加了性能日志开关,如果关闭直接返回,不创建Stopwatch,
在OnActionExecuted中回去到的Stopwatch是null 则直接返回(也可以用性能日志开关做判断),不处理后续。
如果Controll、Action添加了NoLog特性,则不记录性能日志

        private static bool SkipLogging(ActionExecutingContext actionContext)
{
if (!ConfigHelper.IsPerformanceLog) return true;
return actionContext.ActionDescriptor.GetType().GetCustomAttributes(typeof(NoLogAttribute), false).Any() ||
actionContext.Controller.GetType().GetCustomAttributes(typeof(NoLogAttribute), false).Any();
}
  /// <summary>
  /// 忽略性能日志记录特性
  /// </summary>
  [AttributeUsage(AttributeTargets.Method | AttributeTargets.Class, Inherited = true)]
  public class NoLogAttribute : Attribute
  {
  }

八、异常过滤器

   /// <summary>
/// 异常拦截器
/// </summary>
public class ExceptionFilter : IExceptionFilter
{
ILogWrite _logWrite;
public ExceptionFilter(ILogWrite logWrite)
{
_logWrite = logWrite;
} /// <summary>
///
/// </summary>
/// <param name="actionExecutedContext"></param>
/// <param name="cancellationToken"></param>
/// <returns></returns>
public void OnException(ExceptionContext context)
{
BizResult<bool> biz; var paramenters = context.HttpContext.Items[ConfigHelper.FilterActionArguments].ToString();
try
{
biz = new BizResult<bool>(false, (int)B2CBizCode.Exception, context.Exception.Message); if (context.Exception.InnerException != null)
biz.SysMessage += ":" + context.Exception.InnerException.Message; if (ConfigHelper.IsPerformanceLog)
{
var watch = context.HttpContext.Items[ConfigHelper.HttpRequestStopWatcher] as Stopwatch;
watch?.Stop(); var name = context.ActionDescriptor.GetType().GetProperty("ActionName").GetValue(context.ActionDescriptor).ToString(); _logWrite.InfoAsync(new
{
CreateTime = DateTime.Now,
Method = name,
TimeSpan = watch.Elapsed,
IsSuccess = false,
Content = paramenters,
Code = ((B2CBizCode)biz.BusinessCode).ToString(),
Message = biz.BusinessMessage
}.Serialize());
}
}
catch (Exception ex)
{
biz = new BizResult<bool>(false, (int)B2CBizCode.Exception, ex.Message);
}
context.Result = new ApplicationErrorResult(biz); _logWrite?.ErrorAsync($"链接访问出错:{context.HttpContext.Request.Path}", context.HttpContext.Request.Method, this.GetType().Name, context.Exception, paramenters);
return;
}
} public class ApplicationErrorResult : ObjectResult
{
public ApplicationErrorResult(object value) : base(value)
{
StatusCode = (int)HttpStatusCode.InternalServerError;
}
}

九 、添加Autofac,Autofac比.NET Core自带的 Ioc更好用。 NuGetAPI 项目中添加Autofac.Configuration、Autofac.Extensions.DependencyInjection 两个引用 然后 ConfigureServices方法中添加Ioc容器

     public IServiceProvider ConfigureServices(IServiceCollection services)
{
ConfigHelper.Init(Configuration["ConfigZookeeperAddress"], Configuration["ConfigNodePath"]);
services.AddSingleton<ILogWrite, LogWrite>(); services.AddMvc(options =>
{
options.Filters.Add<AuthorizationFilter>();
options.Filters.Add<ExceptionFilter>();
options.Filters.Add<PerformanceLogFilter>();
}); var builder = new ContainerBuilder();//实例化 AutoFac 容器
builder.Populate(services); // TODO: 这里添加其他需要注入类的注册 ApplicationContainer = builder.Build();
return new AutofacServiceProvider(ApplicationContainer);
}

至此.NET Core API的 拦截器、配置管理、日志、Ioc 设置已完成。

public IServiceProvider ConfigureServices(IServiceCollection services)        {            ConfigHelper.Init(Configuration["ConfigZookeeperAddress"], Configuration["ConfigNodePath"]);            services.AddSingleton<ILogWrite, LogWrite>();
            services.AddMvc(options =>            {                options.Filters.Add<AuthorizationFilter>();                options.Filters.Add<ExceptionFilter>();                options.Filters.Add<PerformanceLogFilter>();            });
            var builder = new ContainerBuilder();//实例化 AutoFac  容器                        builder.Populate(services);
            // TODO: 这里添加其他需要注入类的注册
            ApplicationContainer = builder.Build();            return new AutofacServiceProvider(ApplicationContainer);        }

从零开始搭建.NET Core 2.0 API(学习笔记一)的更多相关文章

  1. node+webpack环境搭建 vue.js 2.0 基础学习笔记

    npm install -g vue //全局安装vue npm install -g webpack //全局安装webpack npm install -g vue-cli //全局安装vue-c ...

  2. Windows录音API学习笔记(转)

    源:Windows录音API学习笔记 Windows录音API学习笔记 结构体和函数信息  结构体 WAVEINCAPS 该结构描述了一个波形音频输入设备的能力. typedef struct { W ...

  3. Windows录音API学习笔记

    Windows录音API学习笔记 结构体和函数信息  结构体 WAVEINCAPS 该结构描述了一个波形音频输入设备的能力. typedef struct { WORD      wMid; 用于波形 ...

  4. Windows录音API学习笔记--转

    Windows录音API学习笔记 结构体和函数信息  结构体 WAVEINCAPS 该结构描述了一个波形音频输入设备的能力. typedef struct { WORD      wMid; 用于波形 ...

  5. TCP协议和socket API 学习笔记

    本文转载至 http://blog.chinaunix.net/uid-16979052-id-3350958.html 分类:  原文地址:TCP协议和socket API 学习笔记 作者:gilb ...

  6. 【笔记目录2】【jessetalk 】ASP.NET Core快速入门_学习笔记汇总

    当前标签: ASP.NET Core快速入门 共2页: 上一页 1 2  任务27:Middleware管道介绍 GASA 2019-02-12 20:07 阅读:15 评论:0 任务26:dotne ...

  7. ASP.NET MVC Web API 学习笔记---第一个Web API程序

    http://www.cnblogs.com/qingyuan/archive/2012/10/12/2720824.html GetListAll /api/Contact GetListBySex ...

  8. Node.js API 学习笔记

    常用 API 学习笔记 url 函数 url.parse: 解析 url 地址 url.resolve: 向 url 地址添加或替换字段 url.format: 生成 url 地址 querystri ...

  9. ASP.NET Core 1.0: API的输入参数

    Web API是需要接受参数的,譬如,通常用于创建数据的POST method需要接受输入数据,而用于GET method也需要接受一些可选参数,譬如:为了性能起见,控制返回数据的数量是至关重要的. ...

随机推荐

  1. 洛谷【AT2827】LIS

    浅谈\(DP\):https://www.cnblogs.com/AKMer/p/10437525.html 题目传送门:https://www.luogu.org/problemnew/show/A ...

  2. Mybatis 一对一(OneToOne)关系映射__INSERT

    今天测试Ibatis的一对一的关联映射时总是出现错误,其中很多的错误都是自己不小心写错的..现把整个Ibatis源代码记录下来,以便以后熟记: 1.数据库脚本: CREATE TABLE t_pers ...

  3. Django 多条件多表查询实例问题

    当时想做一个多条件查询,但是对于要查询的信息,是分布在不同的表里,这就涉及到了多表查询问题. DjangoBook里提到了一些查询的方式,但是不够全面,就去百度搜了下. 当去网上百度搜多表查询,或多条 ...

  4. SUSE eth0 No such device

    删除 etc/udev/rules.d/70-persistent-net.rules 文件  之后重启让系统重新生成eth0配置文件 rm -f etc/udev/rules.d/70-persis ...

  5. 文件锁简单操作(lockfileEx\unlockfileEx)

    #include "stdafx.h"#include <Windows.h>#include <iostream> using namespace std ...

  6. 服务器启动时Webapp的web.xml中配置的加载顺序

    一 1.启动一个WEB项目的时候,WEB容器会去读取它的配置文件web.xml,读取<listener>和<context-param>两个结点. 2.紧急着,容创建一个Ser ...

  7. MySQL学习笔记之一---字符编码和字符集

    前言: 一般来说,出现中文乱码,都是客户端和服务端字符集不匹配导致的原因. (默认未指定字符集创建的数据库表,都是latinl字符集, 强烈建议使用utf8字符集)   保证不出现乱码的思想:保证客户 ...

  8. python dict.fromkeys()研究

    def unique(seq): #return [x for x in my_list if x not in locals()['_[1]']] return {}.fromkeys(seq).k ...

  9. Linux系统的安装(centos的下载地址:http://mirror.symnds.com/distributions/CentOS-vault/6.3/isos/i386/,选择:CentOS-6.3-i386-bin-DVD1.iso 这个下载并进行安装)

    1.首先打开虚拟机: 在上面的那个按钮旁有一个下拉的符号,点开后会看到一个进入固件的按钮,直接点击进去. 便会进入这个界面: 在这个界面其实我们不需要该任何的东西,但是我们需要进入boot界面看一眼, ...

  10. sh 脚本重启/更新 Tomcat 项目

    一.项目文件为一个 jar 包,无须解压 重启 Tomcat 项目 #!/bin/bash echo "kill hot-jdt" kill -9 `ps -ef|grep hot ...