• 技术文章 >后端开发 >C#.Net教程

    HttpClient调用ASP.NET Web API的图文详解

    Y2JY2J2017-05-03 13:53:50原创1486
    本篇文章主要介绍了通过HttpClient 调用ASP.NET Web API示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    在前面两篇文章中我们介绍了ASP.NET Web API的基本知识和原理,并且通过简单的实例了解了它的基本(CRUD)操作。我们是通过JQuery和Ajax对Web API进行数据操作。这一篇我们来介绍一下使用HttpClient的方式来对Web API进行数据操作。

    这里我们还是继续使用对Product的操作实例来演示一下它的基本应用。

    创建ASP.NET Web API应用程序

    在VS中选择创建一个ASP.NET Web Application应用程序,在向导的下一个窗口中选择Web API模板。

    创建Model

    这里我们在Models文件夹下创建一个简单的Product model类,用来传递数据。

    在Models文件夹上点击右键,选择Add -> Class

      public class Product
      {
        public int ProductID { get; set; }
        public string ProductName { get; set; }
        public decimal Price { get; set; }
        public int Count { get; set; }
        public string Description { get; set; }
      }

    创建Cotroller

    接着在Controllers文件夹下创建一个API Controller, 命名为"ProductsController"。

    在Controllers文件夹上点击右键,选择Add -> Controller ,在弹出向导中选择Web API 2 Controller - Empty

    在向导下一步中输入API Controller name为"ProductsController"。

    因为我们需要通过HttpClient的方式来调用Web API,所以这里我们还需要创建一个MVC Controller。

    同样在Controllers文件夹上点击右键,选择Add -> Controller ,在弹出向导中选择MVC 5 Controller - Empty

    在向导下一步中输入MVC 5 Controller name为"ProductController"。

    创建Web API方法(CRUD)

    这里我们依然使用模拟的数据创建简单的CRUD Web API方法。前面的章节有详细讲解到,这里就不细说了。直接上代码。

      public class ProductsController : ApiController
      {
        // Mock product list
        public static List<Product> productList = initProductMockDataList();
    
        private static List<Product> initProductMockDataList()
        {
          return new List<Product>()
          {
            new Product {ProductID=1,ProductName="Product A",Price=1000000,Count=5,Description="Description A"},
            new Product {ProductID=2,ProductName="Product B",Price=200000,Count=2,Description="Description B"},
            new Product {ProductID=3,ProductName="Product C",Price=500000,Count=8,Description="Description C"},
            new Product {ProductID=4,ProductName="Product D",Price=80000,Count=10,Description="Description D"},
            new Product {ProductID=5,ProductName="Product E",Price=300000,Count=3,Description="Description E"}
          };
        }
    
        public IEnumerable<Product> Get()
        {
          return productList;
        }
    
        public Product Get(int id)
        {
          return productList.Where(p => p.ProductID == id).FirstOrDefault();
        }
    
        public void Post([FromBody]Product product)
        {
          var lastProduct = productList.OrderByDescending(p => p.ProductID).FirstOrDefault();
          int newProductID = lastProduct.ProductID + 1;
          product.ProductID = newProductID;
    
          productList.Add(product);
        }
    
        public void Put([FromBody]Product product)
        {
          var currentProduct = productList.Where(p => p.ProductID == product.ProductID).FirstOrDefault();
          if (currentProduct != null)
          {
            foreach (var item in productList)
            {
              if (item.ProductID.Equals(currentProduct.ProductID))
              {
                item.ProductName = product.ProductName;
                item.Price = product.Price;
                item.Count = product.Count;
                item.Description = product.Description;
              }
            }
          }
        }
    
        public void Delete(int id)
        {
          Product product = productList.Where(p => p.ProductID == id).FirstOrDefault();
    
          productList.Remove(product);
        }
      }

    通过JQuery和Ajax调用MVC Controller,在MVC Controller中通过HttpClient调用Web API

    Web API中的(CRUD)方法创建完成,接下来我们就分别来看看对各个方法的数据操作。

    1.获取Product列表

    打开我们创建好的MVC 5 Controller文件ProductController。使用HttpClient的方式来调用我们Web API中的列表方法。

    首先需要引入System.Net.Http

    using System.Net.Http;

    接下来为我们的Web API地址定义一个公共静态变量。

    public static readonly Uri _baseAddress = new Uri("http://localhost:21853/");
    
        //
        // GET: /Product/
        public ActionResult Index()
        {
          return View();
        }
    
        public JsonResult GetProductList()
        {
          List<Product> productList = null;
          Uri address = new Uri(_baseAddress, "/api/products");
    
          using (var httpClient = new HttpClient())
          {
            var response = httpClient.GetAsync(address).Result;
    
            if (response.IsSuccessStatusCode)
              productList = response.Content.ReadAsAsync<List<Product>>().Result;
          }
    
          return Json(productList, JsonRequestBehavior.AllowGet);
        }

    这里我们需要通过点击按钮,通过Ajax调用来获取Product列表数据,所以这里我们使用JsonResult返回数据。

    接下来,我们就来创建View。

    文件夹Views->Product下创建一个View,名为"Index"。打开Index View,修改页面代码如下:

    @{
      Layout = null;
    }
    
    <!DOCTYPE html>
    
    <html>
    <head>
      <meta name="viewport" content="width=device-width" />
      <title>Index</title>
      <script src="~/Scripts/jquery-1.10.2.min.js" type="text/javascript"></script>
    </head>
    <body>
      <p style="background-color: #008000; padding: 10px; margin: 5px; width: 45%;">
        <p style="font-weight: bold; margin-bottom: 5px;">Get Product List</p>
        <p style="padding-bottom:5px;"><input id="btnGetProductList" name="btnGetProductList" type="button" value="Get Product List" /></p>
        <p id="products"></p>
      </p>
      </body>
    </html>

    接着,我们要做的是,当点击Get Product List按钮是加载Product List,代码实现如下:

        $('#btnGetProductList').click(function () {
          $.ajax({
            url: '/Product/GetProductList',
            type: 'GET',
            dataType: 'json'
          }).success(function (result) {
            DisplayProductList(result);
          }).error(function (data) {
            alert(data);
          });
        });
    
        // Display product list
        function DisplayProductList(result) {
          var productTable = $("<table cellpadding='3' cellspacing='3'></table>");
          var productTableTitle = $("<tr><th>Product ID</th><th>Product Name</th><th>Price</th><th>Count</th><th>Description</th></tr>");
          productTableTitle.appendTo(productTable);
    
          for (var i = 0; i < result.length; i++) {
            var productTableContent = $("<tr><td>"
              + result[i].ProductID + "</td><td>"
              + result[i].ProductName + "</td><td>"
              + result[i].Price + "</td><td>"
              + result[i].Count + "</td><td>"
              + result[i].Description + "</td></tr>");
    
            productTableContent.appendTo(productTable);
          }
    
          $('#products').html(productTable);
        }

    好了,运行代码。

    点击Get Product List按钮之前如下:

    点击Get Product List按钮之后如下:

    Product数据列表加载成功。

    2.获取单条Product数据

    这里我们的做法是在搜索框里输入Product ID,然后点击Get Product按钮,查找出这条Product信息。

    首先,我们先完成在ProductController中使用HttpClient调用Web API中获取单条Product数据的方法。

        public JsonResult GetSingleProduct(int id)
        {
          Uri address = new Uri(_baseAddress, "/api/products/" + id);
          Product product = null;
    
          using (var httpClient = new HttpClient())
          {
            var response = httpClient.GetAsync(address).Result;
    
            if (response.IsSuccessStatusCode)
              product = response.Content.ReadAsAsync<Product>().Result;
          }
    
          return Json(product, JsonRequestBehavior.AllowGet);
        }

    接着,来到Index View页面中添加一个搜索Product ID的textbox以及一个Get Product的按钮。

      <p style="background-color: #9ACD32; padding: 10px; margin: 5px; width: 45%; ">
        <p style="font-weight:bold;margin-bottom:5px;">Get Single Product</p>
        <p>Product ID: <input id="txtSearchProductID" name="txtSearchProductID" type="text" /> <input id="btnGetProduct" name="btnGetProduct" type="button" value="Get Prdouct" /></p>
        <p id="product"></p>
      </p>

    为按钮Get Product按钮添加Ajax方法

        $('#btnGetProduct').click(function () {
          if ($('#txtSearchProductID').val().trim() != "") {
            $.ajax({
              url: '/Product/GetSingleProduct?id=' + $('#txtSearchProductID').val(),
              type: 'GET',
              dataType: 'json'
            }).success(function (result) {
              if (result != null) {
                $('#product').html("Product ID: " + result.ProductID + "<br/>" + "Product Name: " + result.ProductName + "<br/>" + "Count: " + result.Count + "<br/>" + "Price: " + result.Price + " <br/>" + "Description: " + result.Description);
              } else {
                $('#product').html('');
              }
            }).error(function (data) {
              alert(data);
            });
          }
        });

    运行程序,加载Product列表。

    点击Get Product按钮前:

    这里我们查找Product ID为1的数据

    我们看到Product ID为1的数据成功获取。

    3.新增一条Product

    这里我们创建4个textbox,用来输入Product Name,Count,Price,Description的信息以及一个Create Product按钮。

    首先,我们先完成在ProductController中使用HttpClient调用Web API中新增一条Product数据的方法。

        public JsonResult CreateProduct(Product product)
        {
          bool createSuccess = true;
          Uri address = new Uri(_baseAddress, "/api/products");
    
          using(var httpClient=new HttpClient())
          {
            var response = httpClient.PostAsJsonAsync(address, product).Result;
    
            if (!response.IsSuccessStatusCode)
              createSuccess = false;
          }
    
          return Json(createSuccess, JsonRequestBehavior.AllowGet);
        }

    接着,来到Index View页面中添加4个textbox用来输入Product Name,Count,Price,Description的信息以及一个Create Product按钮。

      <p style="background-color: #CA5100; padding: 10px; margin: 5px; width: 45%;">
        <p style="font-weight:bold;margin-bottom:5px;">Create Product</p>
        <p>
          <table>
            <tr><td> Product Name:</td><td><input id="txtCreateProductName" name="txtCreateProductName" type="text" /></td></tr>
            <tr><td>Count:</td><td><input id="txtCreateCount" name="txtCreateCount" type="text" /></td></tr>
            <tr><td> Price:</td><td><input id="txtCreatePrice" name="txtCreatePrice" type="text" /></td></tr>
            <tr><td> Description:</td><td><input id="txtCreateDescription" name="txtCreateDescription" type="text" /></td></tr>
          </table>
        </p>
        <p>
          <p id="createMessage" style="color:blue;"></p>
          <input id="btnCreateProduct" name="btnCreateProduct" type="button" value="Create Product" />
        </p>
      </p>

    为按钮Create Produc按钮t添加Ajax方法

        $('#btnCreateProduct').click(function () {
          if ($('#txtCreateProductName').val().trim() != "" && $('#txtCreateCount').val().trim() != "" &&
            $('#txtCreatePrice').val().trim() != "" && $('#txtCreateDescription').val().trim() != "") {
            var product = {
              ProductID: 0, ProductName: $('#txtCreateProductName').val(),
              Count: $('#txtCreateCount').val(), Price: $('#txtCreatePrice').val(),
              Description: $('#txtCreateDescription').val()
            };
    
            $.ajax({
              url: '/Product/CreateProduct',
              type: 'GET',
              data: product,
              dataType: 'json'
            }).success(function (result) {
              if (result != null && result) {
                $('#createMessage').html('Product create success.');
                $("#btnGetProductList").trigger('click');
              }
            }).error(function (data) {
              alert(data);
            })
          }
        });

    运行程序,加载Product列表。

    点击Create Product按钮之前:

    输入新增数据,点击Create Product按钮之后:

    我们看到新增数据成功并显示到了Product列表中。

    4.修改Product信息

    这里我们创建5个textbox,用来输入Product ID,Product Name,Count,Price,Description的信息以及一个Update Product按钮。

    首先,我们先完成在ProductController中使用HttpClient调用Web API中修改一条Product数据的方法。

        public JsonResult UpdateProduct(Product product)
        {
          bool updateSuccess = true;
          Uri address = new Uri(_baseAddress, "/api/products");
    
          using (var httpClient = new HttpClient())
          {
            var response = httpClient.PutAsync<Product>(address, product, new JsonMediaTypeFormatter()).Result;
    
            if (!response.IsSuccessStatusCode)
              updateSuccess = false;
          }
    
          return Json(updateSuccess, JsonRequestBehavior.AllowGet);
        }

    接着,来到Index View页面中添加5个textbox用来输入Product ID,Product Name,Count,Price,Description的信息以及一个Update Product按钮。

      <p style="background-color: #007ACC; padding: 10px; margin: 5px; width: 45%;">
        <p style="font-weight:bold;margin-bottom:5px;">Update Product</p>
        <p>
          <table>
            <tr><td>Product ID:</td><td><input id="txtUpdateProductID" name="txtUpdateProductID" type="text" /></td></tr>
            <tr><td> Product Name:</td><td><input id="txtUpdateProductName" name="txtUpdateProductName" type="text" /></td></tr>
            <tr><td>Count:</td><td><input id="txtUpdateCount" name="txtUpdateCount" type="text" /></td></tr>
            <tr><td> Price:</td><td><input id="txtUpdatePrice" name="txtUpdatePrice" type="text" /></td></tr>
            <tr><td> Description:</td><td><input id="txtUpdateDescription" name="txtUpdateDescription" type="text" /></td></tr>
          </table>
        </p>
        <p>
          <p id="updateMessage" style="color:white;"></p>
          <input id="btnUpdateProduct" name="btnUpdateProduct" type="button" value="Update Product" />
        </p>
      </p>

    为按钮Update Product按钮添加Ajax方法

       $('#btnUpdateProduct').click(function () {
          if ($('#txtUpdateProductID').val().trim() != "" && $('#txtUpdateProductName').val().trim() != "" &&
            $('#txtUpdateCount').val().trim() != "" && $('#txtUpdatePrice').val().trim() != null && $('#txtUpdateDescription').val().trim() != "") {
            var product = {
              ProductID: $('#txtUpdateProductID').val(), ProductName: $('#txtUpdateProductName').val(),
              Count: $('#txtUpdateCount').val(), Price: $('#txtUpdatePrice').val(),
              Description: $('#txtUpdateDescription').val()
            };
    
            $.ajax({
              url: '/Product/UpdateProduct',
              type: 'GET',
              data: product,
              dataType: 'json'
            }).success(function (result) {
              if (result != null && result) {
                $('#updateMessage').html('Product update success.');
                $('#btnGetProductList').trigger('click');
              }
            }).error(function (data) {
              alert(data);
            })
          }
        });

    运行代码,加载Product列表。

    点击Update Create按钮之前:

    这里我们修改第一条数据,输入修改信息,点击Update Product按钮之后:

    我们看到Product ID为1的信息成功修改并显示到了Product列表中。

    5.删除Product

    这里我们创建1个textbox,用来输入Product ID的信息以及一个Delete Product按钮。

    首先,我们先完成在ProductController中使用HttpClient调用Web API中删除一条Product数据的方法。

        public JsonResult DeleteProduct(int id)
        {
          bool deleteSuccess = true;
          Uri address = new Uri(_baseAddress, "/api/products/" + id);
    
          using (var httpClient = new HttpClient())
          {
            var response = httpClient.DeleteAsync(address).Result;
    
            if (!response.IsSuccessStatusCode)
              deleteSuccess = false;
          }
    
          return Json(deleteSuccess, JsonRequestBehavior.AllowGet);
        }

    接着,来到Index View页面中添加1个textbox用来输入Product ID的信息以及一个Delete Product按钮。

      <p style="background-color: #B572BA; padding: 10px; margin: 5px; width: 45%; ">
        <p style="font-weight:bold;margin-bottom:5px;">Delete Product</p>
        <p>Product ID: <input id="txtDeleteProductID" name="txtDeleteProductID" type="text" /> <input id="btnDeleteProduct" name="btnDeleteProduct" type="button" value="Delete Prdouct" /></p>
        <p id="deleteMessage" style="color:blue;"></p>
      </p>

    为按钮Delete Product按钮添加Ajax方法

       $('#btnDeleteProduct').click(function () {
          if ($('#txtDeleteProductID').val().trim() != "") {
            $.ajax({
              url: '/Product/DeleteProduct?id=' + $('#txtDeleteProductID').val(),
              type: 'GET',
              dataType: 'json'
            }).success(function (result) {
              if (result != null && result) {
                $('#deleteMessage').html('Product delete success.');
                $('#btnGetProductList').trigger('click');
              }
            }).error(function (data) {
              alert(data);
            })
          }
        });

    运行代码,加载Product列表。

    点击Delete Product按钮之前。

    这里我们输入Product ID为1的数据,点击Delete Product按钮之后:

    我们看到Product ID为1的数据成功删除,并且Product列表中也没有了这条数据。

    以上就是HttpClient调用ASP.NET Web API的图文详解的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:HttpClient asp.net Web API
    上一篇:Winform控件SaveFileDialog关于保存文件用法的代码示例 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • c语言中源文件编译后生成什么文件• C#中GDI+编程10个基本技巧二• 应用绝对路径与相对路径• C/C++深度分析• ASP.NET使用Ajax如何返回Json对象的方法具体介绍
    1/1

    PHP中文网