基于异步的MVC webAPI控制器
MVC – Task-based Asynchronous Pattern (TAP) – Async Controller and SessionLess Controller
In async programming, there are 3 different models for different scenarios :
- Asynchronous Programming Model – APM
- Task Based Asynchronous Programming Model – TAPM
- Evented Asynchronous Programming Model – EAPM
We can use all models in .net framework. It provides related libraries in their own namespaces. The Task-based Asynchronous Pattern (TAP) is based on System.Threading.Tasks.Task and System.Threading.Tasks.Task<TResult> types in the System.Threading.Tasks namespaces.
When we’re developing web application, if we need to develop async applications on web side, we can use this libraries to reflect async behavior. For Instance, if we want to communicate external services or channels at the same time, we might use async controller to avoid operation blocks. When we’re reflecting this behavior in an application, We should think tasks in action level. I mean, surely according to our scenario, if we seperate all actions as different tasks, it can be more useful and manageble.
In .Net Framework MVC Applications, We can use Async Controllers and async actions. For instance please check code below :
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
public class HomeController : AsyncController
{
public NorthwindEntities NorthwindContext { get; set; }
public HomeController()
{
NorthwindContext = new NorthwindEntities();
}
public async Task<ActionResult> Index()
{
var indexViewModel = new IndexViewModel();
Stopwatch stopwatch = new Stopwatch();
stopwatch.Start();
indexViewModel.Categories = await Categories();
indexViewModel.Shippers = await Shippers();
indexViewModel.Currencies = await Currencies();
stopwatch.Stop();
indexViewModel.TotalTime = stopwatch.Elapsed;
return View(indexViewModel);
}
public async Task<List<SelectListItem>> Shippers()
{
var shippers = await NorthwindContext.Shippers.Select(x => new SelectListItem()
{
Text = x.CompanyName,
Value = x.ShipperID.ToString()
}).ToListAsync();
return shippers;
}
public async Task<List<SelectListItem>> Categories()
{
var shippers = await NorthwindContext.Categories.Select(x => new SelectListItem()
{
Text = x.CategoryName,
Value = x.CategoryID.ToString()
}).ToListAsync();
return shippers;
}
public async Task<string> Currencies()
{
WebClient client = new WebClient();
var exchange = await client.DownloadStringTaskAsync("http://www.tcmb.gov.tr/kurlar/today.xml");
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.LoadXml(exchange);
string USDSELL = xmlDoc.SelectSingleNode("Tarih_Date/Currency[@Kod='USD']/BanknoteSelling").InnerXml;
string USDBUY = xmlDoc.SelectSingleNode("Tarih_Date/Currency[@Kod='USD']/BanknoteBuying").InnerXml;
return $"USD Banknote Selling :{USDSELL} - Banknote Buying :{USDBUY}";
}
}
public class IndexViewModel
{
public TimeSpan TotalTime { get; set; }
public List<SelectListItem> Categories { get; set; }
public List<SelectListItem> Shippers { get; set; }
public string Currencies { get; set; }
}
|
And also, if you need to run multiple requests concurrently, use SessionLess controller :
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
[SessionState(SessionStateBehavior.Disabled)]
public class HomeController : Controller
{
public NorthwindEntities NorthwindContext { get; set; }
public HomeController()
{
NorthwindContext = new NorthwindEntities();
}
public async Task<ActionResult> Index()
{
var indexViewModel = new IndexViewModel();
Stopwatch stopwatch = new Stopwatch();
stopwatch.Start();
indexViewModel.Categories = await Categories();
indexViewModel.Shippers = await Shippers();
indexViewModel.Currencies = await Currencies();
stopwatch.Stop();
indexViewModel.TotalTime = stopwatch.Elapsed;
return View(indexViewModel);
}
public async Task<List<SelectListItem>> Shippers()
{
var shippers = await NorthwindContext.Shippers.Select(x => new SelectListItem()
{
Text = x.CompanyName,
Value = x.ShipperID.ToString()
}).ToListAsync();
return shippers;
}
public async Task<List<SelectListItem>> Categories()
{
var shippers = await NorthwindContext.Categories.Select(x => new SelectListItem()
{
Text = x.CategoryName,
Value = x.CategoryID.ToString()
}).ToListAsync();
return shippers;
}
public async Task<string> Currencies()
{
WebClient client = new WebClient();
var exchange = await client.DownloadStringTaskAsync("http://www.tcmb.gov.tr/kurlar/today.xml");
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.LoadXml(exchange);
string USDSELL = xmlDoc.SelectSingleNode("Tarih_Date/Currency[@Kod='USD']/BanknoteSelling").InnerXml;
string USDBUY = xmlDoc.SelectSingleNode("Tarih_Date/Currency[@Kod='USD']/BanknoteBuying").InnerXml;
return $"USD Banknote Selling :{USDSELL} - Banknote Buying :{USDBUY}";
}
}
public class IndexViewModel
{
public TimeSpan TotalTime { get; set; }
public List<SelectListItem> Categories { get; set; }
public List<SelectListItem> Shippers { get; set; }
public string Currencies { get; set; }
}
|
AST
This entry was posted in .Net Framework, ASP.Net, Design Patterns, MVC, Server Side Web Programming,Web Programming and tagged async, asynchronous operations, controller, mvc 5, sessionless, tap, task based asynchronous pattern on July 4, 2016.
基于异步的MVC webAPI控制器的更多相关文章
- SlickOne -- 基于Dapper, Mvc和WebAPI 的快速开发框架
前言:在两年前,项目组推出了基于Dapper,Mvc和WebApi的快速开发框架,随着后续Slickflow产品的实践和应用,今再次对SlickOne项目做以回顾和总结.其目的是精简,持续改进,保持重 ...
- SlickOne敏捷开发框架介绍(一) -- 基于Dapper, Mvc和WebAPI 的快速开发框架
前言:在两年前(最初发布时间:2013年1月9日(csdn),当前文章时间2015年11月10日),项目组推出了基于Dapper,Mvc和WebApi的快速开发框架,随着后续Slickflow产品的实 ...
- C#编译器优化那点事 c# 如果一个对象的值为null,那么它调用扩展方法时为甚么不报错 webAPI 控制器(Controller)太多怎么办? .NET MVC项目设置包含Areas中的页面为默认启动页 (五)Net Core使用静态文件 学习ASP.NET Core Razor 编程系列八——并发处理
C#编译器优化那点事 使用C#编写程序,给最终用户的程序,是需要使用release配置的,而release配置和debug配置,有一个关键区别,就是release的编译器优化默认是启用的.优化代码 ...
- Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC WebAPI 入门开发教程4:控制器方法及参数定义、获取及基础校验属性【Require】。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC WebAPI 入门开发教程5:控制器安全校验属性【HttpGet、HttpPost】【Ack】【Token】【MicroService】。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC WebAPI 入门开发教程6:全局控制器DefaultController与全局事件。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- MVC WebApi 用户验证 (2)
构建ASP.NET MVC5+EF6+EasyUI 1.4.3+Unity4.x注入的后台管理系统(66)-MVC WebApi 用户验证 (2) 前言: 构建ASP.NET MVC5+EF6+E ...
- 构建ASP.NET MVC5+EF6+EasyUI 1.4.3+Unity4.x注入的后台管理系统(66)-MVC WebApi 用户验证 (2)
前言: 构建ASP.NET MVC5+EF6+EasyUI 1.4.3+Unity4.x注入的后台管理系统(65)-MVC WebApi 用户验证 (1) 回顾上一节,我们利用webapi简单的登录并 ...
随机推荐
- HDOJ 1326 Box of Bricks(简单题)
Problem Description Little Bob likes playing with his box of bricks. He puts the bricks one upon ano ...
- Android ListView嵌套Button,Button事件覆盖item事件解决办法
方法就是修改item布局的xml文件: 在根布局里加上: android:descendantFocusability="blocksDescendants" 然后在按钮布局里加上 ...
- Android圆角矩形的实现
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:Android=&quo ...
- HDU_2022——海选女主角
Problem Description potato老师虽然很喜欢教书,但是迫于生活压力,不得不想办法在业余时间挣点外快以养家糊口.“做什么比较挣钱呢?筛沙子没力气,看大门又不够帅...”potato ...
- HDU5196--DZY Loves Inversions 树状数组 逆序数
题意查询给定[L, R]区间内 逆序对数 ==k的子区间的个数. 我们只需要求出 子区间小于等于k的个数和小于等于k-1的个数,然后相减就得出答案了. 对于i(1≤i≤n),我们计算ri表示[i,ri ...
- 写两个线程,一个对n每次加一,一个对n每次减一
public class A{ private static Integer n = 0; } public class B extends A implements Runnable ...
- iOS - UITableViewCell Custom Selection Style Color
Customize UITextView selection color in UITableView Link : http://derekneely.com/2010/01/uitableview ...
- css中margin:0 auto没作用
很多初学制作网页的朋友,可能会遇到的一个常见问题,就是在CSS中加了margin:0 auto;却没有效果,不能居中的问题!margin:0 auto;的意思就是:上下边界为0,左右根据宽度自适应!其 ...
- iOS单元测试(作用及入门提升)
由于只是一些简单实用的东西,学学还是挺不错的.其实单元测试用的好,开发起来也会快很多.单元测试对于我目前来说,就是为了方便测试一些功能是否正常运行,还有调试接口是否能正常使用.有时候你可能是为了测试某 ...
- mysql数据库优化[千万级查询]
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...