前言

  之前几篇文章已经介绍了 Web 与 Web API 的使用方式,接下来将介绍如何在 Windows Form 呼叫 Web API 的方法,要在 WinForm 中使用 Web API 的话,除了可以使用旧有的 WebClient、HttpWebRequest 类别之外,还可以使用新的 HttpClient 类别进行操作,HttpClient 类别是包含在 .Net Framework 4.5 中的 System.Net.Http 之命名空间底下,HttpClient 类别一般来说需要在 .Net Framework 4.5 上才能够使用,但是如果有装 NuGet 的话,可以使用 NuGet 搜寻 Microsoft.Net.Http,NuGet 有提供 4.0 可以使用的安装包。

HttpClient 简介

  在开始使用 WinForm 操作 Web API 前先来介绍一下 HttpClient 类别,HttpClient 类别主要使用于发送 HTTP 要求与接收 HTTP 响应内容,其中包含了一个特点,就是使用异步方式发送 GET、POST、PUT、DELETE 要求,在 MSDN HttpClient 类别文件中提到,使用 HttpClient 的每个请求都拥有各自的连接集区,每个连接集区并不会互相干扰,意思就是可以使用一个实体化的 HttpClient 对象发送给各个不同的 HTTP 服务而不会相互影响。

  HttpClient 能够自订自己的 HttpClient Handler,需要透过继承 DelegatingHandler 的方式并覆写其 SendAsync 方法,参考此 HttpClient Message Handlers文章提到,通常一个服务程序接收到了一个请求并处理其相关内容再回复结果,而过程中可能会经过数个 Handler 层层传递,这种处理模式称为 Delegating Handler,如下图:

  在客户端 HttpClient 透过消息处理程序来处理请求时,默认使用的是 HttpClientHandler 发送请求并得到服务响应,所以我们可以在此将自订的 Message Handler 插入到 HttpClient 与服务之间,如下图,但是在这里不特别说明作法而日后将另辟文章说明,另外对于 Web API 也能够自订Http Message Handler。

使用 HttpClient

  经过以上描述应该对于 HttpClient 有了大概的了解,接下来就来在 Windows Form 里使用 HttpClient 类别操作呼叫 Web API 吧,同样使用前几篇建立好的 Web API 做为基底然后再加入一个窗口应用程序,如下图步骤


 

再来因为 Web API 使用到 JSON 格式,所以透过 NuGet 安装 Json.Net 帮助我们处理 JSON 格式数据。
 

 

  接下来接可以加入一个 Windows Form,简单的把要使用的控制箱加入后切换到程序代码检视,准备开始撰写相关代码。


 

 
  在开始撰写代码之前要先注意一件事,由于先前有提到,HttpClient 类别提供的 GET、POST、PUT、DELETE 方法都是异步方法,所以我们在实际上要去执行 HttpClient 操作的方法上必须加入 async、await 关键词,详细可以参考 使用 Async 和 Await 设计异步程序 (C# 和 Visual Basic)文章。

例如当需要取得 Web API 的所有产品清单时,就可以撰写  GetAllProducts() 方法,如下

1.private async void GetAllProducts()
2.{
3.HttpClient client = new HttpClient();
4.HttpResponseMessage response = await client.GetAsync("http://localhost:49988/api/products");
5.response.EnsureSuccessStatusCode();
6.string responseBody = await response.Content.ReadAsStringAsync();
7.ShowResult(JsonConvert.DeserializeObject<List<Product>>(responseBody));
8.}

  在以上方法中可以看到于方法宣告中加入了 async 宣告此方法为异步方法,之后产生了 HttpClient 对象,并透过该对象的 GetAsync(string) 方法使用异步作业要求取得此 URI 资源,GetAsync(string) 方法将发送一个 GET 请求至 Web API 服务并返回结果,这里可以注意到在 client.GetAsync(URL) 前面加了一个 await 关键词,其原因在于 HttpClient 是异步方法,所以必须要求等待到数据处理完成返回后才能继续下面的步骤,如果不加 await 关键词于前方,GetAsync(string) 方法预设是返回一个 Task<TResult> 的型别。

  而如需要使用 POST 动词的方式呼叫 Web API,就需要改使用 PostAsync(string, httpContent) 方法,如下

1.private async void PostProduct()
2.{
3.HttpClient client = new HttpClient();
4.HttpResponseMessage response = await client.PostAsync("http://localhost:49988/api/products/ASP.NET/WEB/399/12"null);
5.response.EnsureSuccessStatusCode();
6.string responseBody = await response.Content.ReadAsStringAsync();
7.ShowResult(JsonConvert.DeserializeObject<List<Product>>(responseBody));
8.}

  在以上方法中使用 PostAsync(string, httpContent) 方法处理 Post 传输,在此 HttpContent 参数为 null 的原因在此 Web API 的服务是使用 URI 资源的形式,会将参数都至于此 URI 位置中,所以当不是使用此方式的情况下,就必须要自行将参数写入 HttpContent。

  而 Put、Delete 就如同上述内容一样做法,如下

01.private async void PutProduct()
02.{
03.HttpClient client = new HttpClient();
04.HttpResponseMessage response = await client.PutAsync("http://localhost:49988/api/products/1/The WebAPI/MVC/450/5"null);
05.response.EnsureSuccessStatusCode();
06.string responseBody = await response.Content.ReadAsStringAsync();
07.ShowResult(JsonConvert.DeserializeObject<List<Product>>(responseBody));
08.}
09. 
10.private async void DeleteProductById()
11.{
12.HttpClient client = new HttpClient();
13.HttpResponseMessage response = await client.DeleteAsync("http://localhost:49988/api/products/2");
14.response.EnsureSuccessStatusCode();
15.string responseBody = await response.Content.ReadAsStringAsync();
16.ShowResult(JsonConvert.DeserializeObject<List<Product>>(responseBody));
17.}

  参考以上内容完成后,就可以来测试一下,如下


 

以上就是一个 Windows Form 使用 HttpClient 呼叫 Web API 的使用范例,如有任何遗漏或错误,日后将继续修正补充。

范例程序代码http://down1.it165.net/down/201306/it165.net_0603TWebApi.rar

 
转自:http://www.it165.net/pro/html/201306/6052.html

Web API WinForm使用HttpClient呼叫Web API的更多相关文章

  1. 【ASP.NET Web API2】利用HttpClient调用Web API(TODO)

    参照: 在一个空ASP.NET Web项目上创建一个ASP.NET Web API 2.0应用 纯属记录一下遇到的问题: 我们利用HttpClient来调用自宿主方式寄宿的Web API.HttpCl ...

  2. 【WEB API项目实战干货系列】- API访问客户端(WebApiClient适用于MVC/WebForms/WinForm)(四)

    这几天没更新主要是因为没有一款合适的后端框架来支持我们的Web API项目Demo, 所以耽误了几天, 目前最新的代码已经通过Sqlite + NHibernate + Autofac满足了我们基本的 ...

  3. angularjs呼叫Web API

    今早有分享一篇<创建Web API并使用>http://www.cnblogs.com/insus/p/7771428.html 接下来,我再分享一篇,怎样在angularjs去呼叫Web ...

  4. Web API(二):Web API概述

    一.什么是API API(Application Programming Interface)即应用程序编程接口,是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能 ...

  5. 【转载】ASP.NET MVC Web API 学习笔记---第一个Web API程序

    1. Web API简单说明 近来很多大型的平台都公开了Web API.比如百度地图 Web API,做过地图相关的人都熟悉.公开服务这种方式可以使它易于与各种各样的设备和客户端平台集成功能,以及通过 ...

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

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

  7. Asp.Net Web API 2第五课——Web API路由

    Asp.Net Web API 导航   Asp.Net Web API第一课——入门 http://www.cnblogs.com/aehyok/p/3432158.html Asp.Net Web ...

  8. ASP.NET MVC Web API 学习笔记---第一个Web API程序【转】

    http://www.cnblogs.com/qingyuan/archive/2012/10/12/2720824.html 1. Web API简单说明 近来很多大型的平台都公开了Web API. ...

  9. ASP.NET MVC Web API 学习笔记---第一个Web API程序---近来很多大型的平台都公开了Web API

    1. Web API简单说明 近来很多大型的平台都公开了Web API.比如百度地图 Web API,做过地图相关的人都熟悉.公开服务这种方式可以使它易于与各种各样的设备和客户端平台集成功能,以及通过 ...

随机推荐

  1. 跟我学Windows Azure 一 创建Windows Azure试用账号

    我在网上看了很多教程,很大部分都是申请的是国外或者是香港的试用账号,而国内是由世纪互联所代理的,他的申请方式与VS2013的部署设置或多或少还是有些出入,这里我先跟大家一起过一下,在国内如何申请一个w ...

  2. JavaScriptPolyfillShim 在JavaScript中Shim和Polyfill有什么区别?

    在JavaScript的世界里,有两个词经常被提到,那就是Shim和Polyfill,它们指的都是什么,又有什么区别?在本文中,将简短的给大家介绍他们之间的联系和区别.Shim一个shim就是一个库, ...

  3. Linux-Rsync服务器/客户端搭建实战

    一.需求 每晚汇总各机器的操作日志,同步到主服务器进行日志分析. 二.基础知识 rsync 分为服务器端.客户端,服务器端搭建比客户端辛苦一些(也是很简单). rsync 服务器是指以 deamon ...

  4. Web 应用程序中的安全向量 – ASP.NET MVC 4 系列

           Web 程序运行在标准的.基于文本的协议(HTTP 和 HTML)之上,所以特别容易受到自动攻击的伤害.本章主要介绍黑客如何滥用应用程序,以及针对这些问题的应对措施.   威胁:跨站脚本 ...

  5. python-print

    %s,%d就是占位符.还有%r 只是说明这样的对应:%s-->str();%r-->repr(),什么意思呢?就是说%s调用的是str()函数把对象转化为str类型,而%r是调用了repr ...

  6. entity framework自动迁移

    第一步,建立测试项目,普通的WinForm类型,EntityMigration: 第二步,从NuGet为项目添加MySql.Data.Entity,由Oracle提供,我选择人气高的: 第三步,建立实 ...

  7. 【深度学习】之Caffe的solver文件配置(转载自csdn)

    原文: http://blog.csdn.net/czp0322/article/details/52161759 今天在做FCN实验的时候,发现solver.prototxt文件一直用的都是mode ...

  8. 免装版tomcat注册成windows系统服务方法

    如果一台服务器要部署两个应用,而且又各自不受影响的话,只能使用两个端口两个tomcat分别管理 在这里吐槽一下tomcat,为毛停止服务就把所有应用都停了,更新其中一个,就要把所有的都停了,然后更新完 ...

  9. .NET中的动态编译

    代码的动态编译并执行是一个.NET平台提供给我们的很强大的工具用以灵活扩展(当然是面对内部开发人员)复杂而无法估算的逻辑,并通过一些额外的代码来扩展我们已有 的应用程序.这在很大程度上给我们提供了另外 ...

  10. 使用nvm安装node

    安装nvm curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.32.1/install.sh | bash 安装node nvm ...