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 FrameworkASP.NetDesign PatternsMVCServer Side Web Programming,Web Programming and tagged asyncasynchronous operationscontrollermvc 5sessionlesstaptask based asynchronous pattern on July 4, 2016.

基于异步的MVC webAPI控制器的更多相关文章

  1. SlickOne -- 基于Dapper, Mvc和WebAPI 的快速开发框架

    前言:在两年前,项目组推出了基于Dapper,Mvc和WebApi的快速开发框架,随着后续Slickflow产品的实践和应用,今再次对SlickOne项目做以回顾和总结.其目的是精简,持续改进,保持重 ...

  2. SlickOne敏捷开发框架介绍(一) -- 基于Dapper, Mvc和WebAPI 的快速开发框架

    前言:在两年前(最初发布时间:2013年1月9日(csdn),当前文章时间2015年11月10日),项目组推出了基于Dapper,Mvc和WebApi的快速开发框架,随着后续Slickflow产品的实 ...

  3. C#编译器优化那点事 c# 如果一个对象的值为null,那么它调用扩展方法时为甚么不报错 webAPI 控制器(Controller)太多怎么办? .NET MVC项目设置包含Areas中的页面为默认启动页 (五)Net Core使用静态文件 学习ASP.NET Core Razor 编程系列八——并发处理

    C#编译器优化那点事   使用C#编写程序,给最终用户的程序,是需要使用release配置的,而release配置和debug配置,有一个关键区别,就是release的编译器优化默认是启用的.优化代码 ...

  4. Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  5. Taurus.MVC WebAPI 入门开发教程4:控制器方法及参数定义、获取及基础校验属性【Require】。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  6. Taurus.MVC WebAPI 入门开发教程5:控制器安全校验属性【HttpGet、HttpPost】【Ack】【Token】【MicroService】。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  7. Taurus.MVC WebAPI 入门开发教程6:全局控制器DefaultController与全局事件。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  8. MVC WebApi 用户验证 (2)

    构建ASP.NET MVC5+EF6+EasyUI 1.4.3+Unity4.x注入的后台管理系统(66)-MVC WebApi 用户验证 (2)   前言: 构建ASP.NET MVC5+EF6+E ...

  9. 构建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简单的登录并 ...

随机推荐

  1. 黑马程序员_JavaIO流(三)

    字节流File读写操作 字符流: FileReader FileWriter BufferedReader BufferedWrtier 字节流: FileInputStream FileOutput ...

  2. 【7】JAVA---地址App小软件(AddrBusiness.class)(逻辑层)

    这个...没多少好解释的... 表现层的增删改查的具体实现类. package cn.hncu.addr.business; import javax.swing.JOptionPane; impor ...

  3. C# 同步/并发队列ConcurrentQueue (表示线程安全的先进先出 (FIFO) 集合)

    http://msdn.microsoft.com/zh-cn/library/dd267265(v=vs.110).aspx static void Main(string[] args) { // ...

  4. Struts 2零配置

    从struts2.1开始,struts2不再推荐使用Codebehind作为零配置插件,而是改为使用Convention插件来支持零配置,和Codebehind相比,Convention插件更彻底,该 ...

  5. jquery easyui Tab 引入页面的问题

    jQuery Easyui 的tabs插件有两种方式加载某个tab(标签页)上的内容:“href远程请求”和“content本地内容”,本文就两种方式的优缺点进行简单分析和思考. 两者特点: href ...

  6. [转]Android重力感应开发

    http://blog.csdn.net/mad1989/article/details/20848181 一.手机中常用的传感器 在Android2.3 gingerbread系统中,google提 ...

  7. Python 获取Facebook用户的Friends的爱好中的Top10

    CODE; #!/usr/bin/python # -*- coding: utf-8 -*- ''' Created on 2014-8-12 @author: guaguastd @name: f ...

  8. [Angular 2] Async Http

    Async Pipe: The Asynce pipe receive a Promise or Observable as  input and subscribes to the input, e ...

  9. [React Testing] Children with Shallow Rendering

    When testing React components, we often want to make sure the rendered output of the component match ...

  10. snappydb 依赖的jar包

    最近看学习了一下snappydb,因为我用的还是Eclipse但是github上的是as项目所以就考虑用jar包来使用. github地址:https://github.com/nhachicha/S ...