NetCore组件
NetCore之组件写法
本章内容和大家分享的是Asp.NetCore组件写法,在netcore中很多东西都以提供组件的方式来使用,比如MVC架构,Session,Cache,数据库引用等; 这里我也通过调用验证码接口来自定义个组件以此说明如何使用,以及使用时需要注意的场景;
Middleware之hello world
对于netcore来说,通常会在UseStartup<Startup>对应的Startup类中引用组件,这个Startup可以换成自己自定义的其实类,不过需要在UseStartup的时候指向她;这里还是以Startup类为例,通过vs自动生成的文件,在这个类中我们能看到Configure方法体里面包含了:app.UseMvc(),app.UseStaticFiles(),app.xxx()等一些列自带的组件,下面来看下自定义个hello world中组件实例,首先使用静态扩展方法扩展IApplicationBuilder:

1 public static class MiddlewareExtends
2 {
3 /// <summary>
4 /// 测试用例中间件
5 /// </summary>
6 /// <param name="builder"></param>
7 /// <returns></returns>
8 public static IApplicationBuilder UseTest(this IApplicationBuilder builder)
9 {
10 return builder.UseMiddleware<TestMiddleware>();
11 }
12
13 }

使用 builder.UseMiddleware<TestMiddleware>() 来添加自定义组件,组件实现代码如下:

1 public class TestMiddleware
2 {
3 private RequestDelegate _requestDelegate;
4 public TestMiddleware(RequestDelegate requestDelegate)
5 {
6 _requestDelegate = requestDelegate;
7 }
8
9 public Task Invoke(HttpContext context)
10 {
11
12 context.Items["TestMiddleware"] = "hello world,我是TestMiddleware。";
13
14 return _requestDelegate(context);
15 }
16 }

以上是最基础的组件格式;注:
1. 组件必须要有 public Task Invoke(HttpContext context) ,HttpContext是咋们http上下文,Invoke()委托方法,每次程序被访问时就会进入Invoke;
2. 要有 public delegate Task RequestDelegate(HttpContext context); 委托方法,来响应http请求;
到这里咋们hello world就完成了,为了测试方法,我们直接在action中写入如下代码:

1 public IActionResult About()
2 {
3
4 ViewData["Message"] = HttpContext.Items["TestMiddleware"];
5 return View();
6 }

运行结果:

组件异步写法

1 public class TestMiddleware
2 {
3 private RequestDelegate _requestDelegate;
4 public TestMiddleware(RequestDelegate requestDelegate)
5 {
6 _requestDelegate = requestDelegate;
7 }
8
9 public async Task Invoke(HttpContext context)
10 {
11
12 context.Items["TestMiddleware"] = "hello world,我是asyncTestMiddleware。";
13
14 await _requestDelegate(context);
15 }
16 }

仅仅需要async 和 await 组合修饰就行了;
.netcore自定义验证码组件

1 /// <summary>
2 /// 文字验证码
3 /// </summary>
4 public class WenZiCodeMiddleware
5 {
6 private RequestDelegate _requestDelegate;
7 public WenZiCodeMiddleware(RequestDelegate requestDelegate)
8 {
9 _requestDelegate = requestDelegate;
10 }
11
12 public async Task Invoke(HttpContext context)
13 {
14
15 var url = "http://localhost:1001/shenniuapi/WenZiValidateCode";
16 using (HttpClient client = new HttpClient())
17 {
18 client.Timeout = TimeSpan.FromSeconds(60);
19
20 var str = "{\"UserName\": \"神牛步行3\",\"UserPwd\": \"4297f44b13955235245b2497399d7a93\",\"Token\": \"008我是测试\"}";
21 var content = new StringContent(str, Encoding.UTF8, "application/x-www-form-urlencoded");
22 content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
23 var result01 = client.PostAsync(url, content).Result;
24 var stream = await result01.Content.ReadAsStreamAsync();
25 using (var reader = new StreamReader(stream))
26 {
27 var result02 = await reader.ReadToEndAsync();
28 context.Items["codedata"] = result02;
29 }
30 }
31
32 await _requestDelegate(context);
33 }
34 }

我们同样需要再静态扩展方法里面添加如下代码,来加入组件:

1 /// <summary>
2 /// 文字验证码中间件
3 /// </summary>
4 /// <param name="builder"></param>
5 /// <returns></returns>
6 public static IApplicationBuilder UseWenZiValidateCode(this IApplicationBuilder builder)
7 {
8 return builder.UseMiddleware<WenZiCodeMiddleware>();
9 }

在Configure方法中,引用组件: app.UseWenZiValidateCode(); ;Action中,使用组件:

1 public FileResult GetCode()
2 {
3 var data = HttpContext.Items["codedata"].ToString();
4 var code = JsonConvert.DeserializeObject<MoValidateCodeResponse>(data);
5 return File(code.CodeStream, "image/jpeg");
6 }

View试图中代码:
1 GetCode:<img src="/home/GetCode" data-src="/home/GetCode" />
效果展示:

这里需要考虑场景是,我们上面提及到的Invoke方法是任意请求都会进入,那验证码这种功能做成组件是否不是很合理,因为验证码也只有在登陆界面或验证的界面需要用到而已,如我们上面写的验证码组件,每次都会被程序执行这显然不合理,因此个人认为如果你需要自定义组件,那么需要考量:是否每次请求都需要进入您的组件服务,如果不需要的话,那其实没必要弄一个组件,当然感觉很高大上;因此这里我不得不使用静态扩展方法(当然还有其他方式)来重写获取验证码的方法;
静态扩展方法重写验证码组件
由于上面我们在添加组件时有一个静态类了,那么我们直接在上面补充扩展方法:

1 /// <summary>
2 /// 文字验证码
3 /// </summary>
4 /// <param name="context"></param>
5 /// <returns></returns>
6 public static async Task<MoValidateCodeResponse> WenZiCode(this HttpContext context)
7 {
8 var code = default(MoValidateCodeResponse);
9 try
10 {
11 var url = "http://localhost:1001/shenniuapi/WenZiValidateCode";
12 using (HttpClient client = new HttpClient())
13 {
14 client.Timeout = TimeSpan.FromSeconds(60);
15
16 var str = "{\"UserName\": \"神牛步行3\",\"UserPwd\": \"4297f44b13955235245b2497399d7a93\",\"Token\": \"008我是测试\"}";
17 var content = new StringContent(str, Encoding.UTF8, "application/x-www-form-urlencoded");
18 content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
19 var result01 = client.PostAsync(url, content).Result;
20 var stream = await result01.Content.ReadAsStreamAsync();
21 using (var reader = new StreamReader(stream))
22 {
23 var result02 = await reader.ReadToEndAsync();
24 code = await JsonConvert.DeserializeObjectAsync<MoValidateCodeResponse>(result02);
25 }
26 }
27 }
28 catch (Exception ex)
29 {
30 }
31 return code;
32 }

对应的验证码实体类:
这个时候同样来到Action中:

1 public async Task<FileResult> GetCodeAsync()
2 {
3 var code = await HttpContext.WenZiCode();
4
5 return File(code.CodeStream, "image/jpeg");
6 }

修改view试图代码,增加点击验证码图片重新获取新的验证码:

1 <style type="text/css">
2 img{cursor:pointer}
3 </style>
4 <h3>@ViewData["Message"]</h3>
5 <h3>@ViewData["codedata"]</h3>
6 GetCode:<img src="/home/GetCode" data-src="/home/GetCode" />
7 GetCodeAsync:<img src="/home/GetCodeAsync" data-src="/home/GetCodeAsync" />
8
9 <script src="~/lib/jquery/dist/jquery.js"></script>
10 <script>
11 $(function () {
12 $("img").on("click", function () {
13 var img = this;
14 var nowTime = new Date().getTime();
15 var src = $(img).attr("data-src") + "?t=" + nowTime;
16 $(img).attr("src", src);
17 });
18 })
19 </script>

效果图:

NetCore组件的更多相关文章
- Asp.NetCore之组件写法
本章内容和大家分享的是Asp.NetCore组件写法,在netcore中很多东西都以提供组件的方式来使用,比如MVC架构,Session,Cache,数据库引用等: 这里我也通过调用验证码接口来自定义 ...
- .net core2.0+nginx+Ubuntu14.04【一个小白的初次尝试】
新的业务来了,需要使用linux环境部署web服务,作为一个C#的懒惰程序员,就这么上了车[狗脸],废话不多说,跟我一样的小白请看,大神请绕路. 站点暂时没有使用Docker部署,为什么呢,因为我还没 ...
- 跨语言调用Hangfire定时作业服务
跨语言调用Hangfire定时作业服务 背景 Hangfire允许您以非常简单但可靠的方式执行后台定时任务的工作.内置对任务的可视化操作.非常方便. 但令人遗憾的是普遍都是业务代码和hagnfire服 ...
- .NetCore中的日志(1)日志组件解析
.NetCore中的日志(1)日志组件解析 0x00 问题的产生 日志记录功能在开发中很常用,可以记录程序运行的细节,也可以记录用户的行为.在之前开发时我一般都是用自己写的小工具来记录日志,输出目标包 ...
- netcore实践:跨平台动态加载native组件
缘起netcore框架下实现基于zmq的应用. 在.net framework时代,我们进行zmq开发由很多的选择,比较常用的有clrzmq4和NetMQ. 其中clrzmq是基于libzmq的Int ...
- .Netcore之日志组件Log4net、Nlog性能比较
转载请注明出处http://www.cnblogs.com/supernebula/p/7506993.html .Netcore之Log4net.Nlog性能比较 最近在写一个开源.netcore ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (六)实现业务功能
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (五)授权过滤参数处理
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (四)授权过滤
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
随机推荐
- python做图笔记
1. 工具选择 了解了基本python,rodeo,anaconda套件这三种工具. (1)基本python,下载安装python的最新版(目前是python3.7).注意要使用安装版.安装好后,一般 ...
- listen 54
Our library is also open for the local residents. People are doing their Christmas shopping. Later t ...
- 机器学习 F1-Score, recall, precision
在机器学习,模式识别中,我们做分类的时候,会用到一些指标来评判算法的优劣,最常用的就是识别率,简单来说,就是 Acc=Npre/Ntotal 这里的 Npre表示预测对的样本数,Ntotal表示测试集 ...
- MYSQL_与excel结合在excel中用&连接符快速创建表头_20161125
excel &连接符快速创建表头 复制c列内容 CREATE TABLE A0001restaurant ( #用户明细表 城市 ), 区块 ), 用户ID ), 用户名称 ), 用户地址 ) ...
- 【Lintcode】382.Triangle Count
题目: Given an array of integers, how many three numbers can be found in the array, so that we can bui ...
- AtCoder Grand Contest 004 C:AND Grid
题目传送门:https://agc004.contest.atcoder.jp/tasks/agc004_c 题目翻译 给你一张网格图,指定的格子是紫色的,要求你构造出两张网格图,其中一张你可以构造一 ...
- BI 底座——数据仓库技术(Data Warehouse)
在开始喷这个主题之前,让我们先看看数据仓库的官方定义: 数据仓库(Data Warehouse)是一个面向主题的(Subject Oriented).集成的(Integrate).相对稳定的(Non- ...
- 如何解决 Matlab 画图时中文显示乱码的问题?
使用的是win10系统,从前几个月某一天,我的matlab的figure里的中文都变成了口口.很是郁闷,还以为是动到了什么配置引起的. 前几天更新了matlab 2018b,发现还有这个问题.就觉得不 ...
- nginx中有关命令和日志切割,配置文件加载的详细阐述
一.Nginx简介 Nginx (“engine x”) 是俄罗斯人Igor Sysoev(塞索耶夫)编写的一款高性能的 HTTP 和反向代理服务器.Nginx 已经在俄罗斯最大的门户网站── Ram ...
- POI 中的CellType类型以及值的对应关系
操作使用POI接口,了解CellType的类型和值的对应关系. CellType 类型 值 CELL_TYPE_NUMERIC 数值型 0 CELL_TYPE_STRING 字符串型 1 CELL_T ...