Asp.Net Web API(六)

简介: Asp.Net Web API不可以需要IIS。可以自己在主机上承载一个Web API     创建WebAPI.Server项目 创建一个控制器项目的服务端  在Nuget中添加Microsoft.

     Asp.Net Web API不可以需要IIS。可以自己在主机上承载一个Web API

     创建WebAPI.Server项目

 创建一个控制器项目的服务端

 

 在Nuget中添加Microsoft.AspNet.WebApi.SelfHost

  创建Model与Controller

       首先在服务端添加一个Product类型

namespace WebAPI.Server.Models
{
    public class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Category { get; set; }
        public decimal Price { get; set; }
    }
}

然后添加一个ProductController控制器,这个控制器继承于Sytem.Web.Http.ApiController。记得扩展引用System.Web.Http

using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Web.Http;
using WebAPI.Server.Models;

namespace WebAPI.Server.Controller
{
    public class ProductController:ApiController
    {
       private static IList<Product>   products;
       static ProductController()
        {
            products = new List<Product>();
            products.Add(new Product { Id = 1, Name = "Tomato Soup", Category = "Groceries", Price = 1 });
            products.Add(new Product { Id = 2, Name = "Yo-yo", Category = "Toys", Price = 3.75M });
            products.Add(new Product { Id = 3, Name = "Hammer", Category = "Hardware", Price = 16.99M });
        }

      
        /// <summary>
        /// 获取所有商品
        /// </summary>
        /// <returns></returns>
        public IEnumerable<Product> GetProducts()
        {
            return products;
        }
        /// <summary>
        /// 获取商品
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        public Product GetProductById(int id)
        {
            var product = products.FirstOrDefault((p) => p.Id == id);
            if (product == null)
            {
                throw new HttpResponseException(HttpStatusCode.NotFound);
            }
            return product;
        }
        /// <summary>
        /// 添加商品
        /// </summary>
        /// <param name="product"></param>
        public void  PostProduct(Product product)
        {
            products.Add(product);
        }
       /// <summary>
       /// 修改商品
       /// </summary>
       /// <param name="id"></param>
       /// <param name="product"></param>
        public void PutProduct(int id,Product product)
        {
           var pro= products.SingleOrDefault(y => y.Id == id);
            pro.Category = product.Category;
            pro.Name = product.Name;
            pro.Price = product.Price;
        }
        /// <summary>
        /// 删除商品
        /// </summary>
        /// <param name="id"></param>
        public void DeleteProduct(int id)
        {
            products.Remove(products.SingleOrDefault(y => y.Id == id));
        }
    }
}

 

承载Web API

  在Program类中添加如下引用

using System.Http;
using System.Web.Http.SelfHost;

然后再添加如下代码

using System;
using System.Web.Http;
using System.Web.Http.SelfHost;

namespace WebAPI.Server
{
    class Program
    {
        static void Main(string[] args)
        {
            //创建HTTP服务的配置类
            var config = new HttpSelfHostConfiguration("http://localhost:7777");
            config.Routes.MapHttpRoute(
                "API Default","api/{Controller}/{id}",
                new { id=RouteParameter.Optional}
              );
            //创建System.Web.Http的实现类
            using (HttpSelfHostServer server = new HttpSelfHostServer(config))
            {
                server.OpenAsync().Wait();
                Console.WriteLine("服务端已开启");
                Console.Read();
            }
        }
    }
}

 这个应用程序监听“http://localhost:7777”。默认情况下,侦听一个特殊的HTTP URL是需要管理员权限的。运行上面应用程序时,可能会得到这样一个错误:“HTTP could not register URL http://+:7777",这儿有两种方式去避免这个错误:

    1.以管理员身份运行Visual Studio。

  2.使用Netsh.exe给与你的账号权限去保留这个URL。

若要使用Netsh.exe,以管理员身份打开命令提示框,并键入以下命令:

netsh http add urlacl url=http://+:7777/ user=machine\username

其中machine\username是您的用户帐户。

当你使用完自托管的时候,最好是确定删除这个保留的URL。

netsh http delete urlacl url=http://+:7777/

然后启动服务端

 

创建WebAPI.Client 项目

  创建一个控制台项目的客户端

在Nuget中添加Microsoft.AspNet.WebApi.Client

添加Model

   在客户端中添加一个与服务端具有相同属性的Product的实体模型

namespace WebAPI.Client.Models
{
    class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Category { get; set; }
        public decimal Price { get; set; }
    }
}

创建HttpClient辅助类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;
using WebAPI.Client.Models;

namespace WebAPI.Client
{
   public  class MyHtppClient
    {
        HttpClient client;
        public MyHtppClient(String uri)
        {
            //初始化客户端
            client = new HttpClient();
            client.BaseAddress = new Uri(uri);
            //为请求头添加一项。
            client.DefaultRequestHeaders.Accept.Add(
                new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json")
                );
        }
        /// <summary>
        /// 获取所有商品
        /// </summary>
        public void GetAll()
        {
            //获取
            HttpResponseMessage message = client.GetAsync("api/product").Result;
            if(message.IsSuccessStatusCode)
            {//成功返回
                var produsts = message.Content.ReadAsAsync<IEnumerable<Product>>().Result;
                foreach (var item in produsts)
                {
                    Console.WriteLine($"商品编号:{item.Id};商品名称:{item.Name};商品价格:{item.Price};商品类型:{item.Category}");
                }
            }
        }
        public void GetbyId(int id)
        {
            HttpResponseMessage message = client.GetAsync($"api/product/{id}").Result;
            if(message.IsSuccessStatusCode)
            {
                var product = message.Content.ReadAsAsync<Product>().Result;
                Console.WriteLine($"商品编号:{product.Id};商品名称:{product.Name};商品价格:{product.Price};商品类型:{product.Category}");
            }
        }
        public void Add(Product product)
        {
            HttpResponseMessage message = client.PostAsJsonAsync("api/product", product).Result;
            Console.WriteLine("{0} ({1})", (int)message.StatusCode, message.ReasonPhrase);
        }
        public void Modify(int id,Product product)
        {
            HttpResponseMessage message = client.PutAsJsonAsync($"api/product/{id}", product).Result;
            Console.WriteLine("{0} ({1})", (int)message.StatusCode, message.ReasonPhrase);
        }
        public void Delete(int id)
        {
            HttpResponseMessage message = client.DeleteAsync($"api/product/{id}").Result;
            Console.WriteLine("{0} ({1})", (int)message.StatusCode, message.ReasonPhrase);
        }
    }
}

然后我们在main方法中测试所有方法

namespace WebAPI.Client
{
    class Program
    {
        static void Main(string[] args)
        {
            MyHtppClient myHtppClient = new MyHtppClient("http://localhost:7777");
            myHtppClient.GetAll();
        }
    }
}

其它方法在这就不再做测试

配置HttpClient

   如果要配置HttpClient,就创建一个WebRequestHandler实例,设置它的属性并将它传递给HttpClient构造函数

WebRequestHandler handler = new WebRequestHandler()
{
    AllowAutoRedirect = false,
    UseProxy = false 
};
HttpClient client = new HttpClient(handler);

WebRequestHandlerHttpMessageHandler派生。您还可以通过从HttpMessageHandler派生插入自定义消息处理程序中

相关文章
|
30天前
|
JSON API 数据库
解释如何在 Python 中实现 Web 服务(RESTful API)。
解释如何在 Python 中实现 Web 服务(RESTful API)。
23 0
|
2月前
|
IDE Java API
使用Java Web技术构建RESTful API的实践指南
使用Java Web技术构建RESTful API的实践指南
|
30天前
|
XML JSON API
通过Flask框架创建灵活的、可扩展的Web Restful API服务
通过Flask框架创建灵活的、可扩展的Web Restful API服务
|
1月前
|
缓存 监控 API
Python Web框架FastAPI——一个比Flask和Tornada更高性能的API框架
Python Web框架FastAPI——一个比Flask和Tornada更高性能的API框架
56 0
|
1月前
|
JSON API 数据格式
构建高效Python Web应用:Flask框架与RESTful API设计实践
【2月更文挑战第17天】在现代Web开发中,轻量级框架与RESTful API设计成为了提升应用性能和可维护性的关键。本文将深入探讨如何使用Python的Flask框架来构建高效的Web服务,并通过具体实例分析RESTful API的设计原则及其实现过程。我们将从基本的应用架构出发,逐步介绍如何利用Flask的灵活性进行模块化开发,并结合请求处理、数据验证以及安全性考虑,打造出一个既符合标准又易于扩展的Web应用。
622 4
|
1月前
|
存储 PHP 数据库
使用Net2FTP轻松打造免费的Web文件管理器并公网远程访问
使用Net2FTP轻松打造免费的Web文件管理器并公网远程访问
|
2月前
|
前端开发 JavaScript API
前端秘法番外篇----学完Web API,前端才能算真正的入门
前端秘法番外篇----学完Web API,前端才能算真正的入门
|
2月前
|
API 网络架构
解释 RESTful API,以及如何使用它构建 web 应用程序。
解释 RESTful API,以及如何使用它构建 web 应用程序。
87 0
|
2月前
|
存储 前端开发 搜索推荐
前端开发中值得关注的三个Web API
【2月更文挑战第4天】Web API是前端开发中非常重要的一部分,它们为开发者提供了众多的功能和特性,帮助我们构建更加高效、优美的Web应用。本文将介绍三个值得关注的Web API,包括Web Storage、Geolocation和Web Notifications,希望能够对前端开发者有所帮助。
|
2月前
|
缓存 安全 API
深入理解Web开发中的RESTful API设计
在当今快速演进的技术世界中,RESTful API已成为构建现代Web应用不可或缺的一部分。它不仅促进了前后端的分离发展,还为不同平台间的数据交换提供了一种高效、标准化的方式。本文旨在深入探讨RESTful API的设计原则和最佳实践,通过具体示例说明如何设计易于维护、可扩展和安全的API。我们将从REST的基本概念出发,逐步深入到资源命名、HTTP方法的恰当使用、状态码的选择、以及安全性考虑等方面,为读者提供一个全面而深入的视角,帮助大家更好地理解和运用RESTful API。