美文网首页
WebApi入门

WebApi入门

作者: 扶不起的蝌蚪 | 来源:发表于2021-08-03 23:14 被阅读0次

    WebApi实质上是进行数据处理和返回的一个服务,在前后分离的工程中起着关键性的桥梁作用

    新建WebApi工程

    打开visual studio,ctrl+shift+N新建WebApi项目

    新建一个空项目,先不要勾选 为HTTPS位置

    在vs给我们创建的工程项目中,HomeController实际上是MVC模块的Controller

    ApiController才是我们所需要进行业务开发的地方

    F10运行项目,会看到WebApi的Home Page页面,里面展示了一系列的向导


    在浏览器地址输入http://localhost:61035/api/result,会发现,页面返回了一个XML

    但是我们在实际的业务开发中,都是用的JSON格式的数据,那么我们用postman访问这个地址试试



    会发现接口返回的是JSON格式的数据

    这个返回的数据是怎么实现的呢,我们打开工程的Controllers/ValuesController.cs

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    
    namespace WebApi.Controllers
    {
        public class ValuesController : ApiController
        {
            // GET api/values 
            //这里可以看到我们在请求地址的时候,实际上触发了这个行为(action)
            public IEnumerable<string> Get()
            {
                return new string[] { "value1", "value2" };
            }
            // GET api/values/5 这里传入的id参数,
            //也就是说如果我们请求http://localhost:61035/api/values/1
            //或者http://localhost:61035/api/values/1地址的时候
            //接口会返回一个"value"的字符串
            public string Get(int id)
            {
                return "value";
            }
        }
    }
    

    那么http://localhost:61035/api/values/中的api这又是从何而来的呢?
    我们打开APP_Start/WebApiConfig.cs

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web.Http;
    
    namespace WebApi
    {
        public static class WebApiConfig
        {
            public static void Register(HttpConfiguration config)
            {
                // Web API 配置和服务
    
                // Web API 路由
                config.MapHttpAttributeRoutes();
    
                config.Routes.MapHttpRoute(
                    //name在一个项目中不允许重复
                    name: "DefaultApi",
                    //api实际上就是访问controller的前一级,如果我们把api改成aaa,那么我们访问api/后面的任何接口都是无效的
                    //{controller}controller实际上就是Controller文件夹下面的XXXXController类文件的前缀
                    //{id}实际上就是请求controller里面类方法所传递的参数,默认是可选的
                    routeTemplate: "api/{controller}/{id}",  //
                    defaults: new { id = RouteParameter.Optional }
                );
            }
        }
    }
    

    通过上面的分析,我们可以发现,ValuesController 上通过定义不同的方法,并且及进行方法的重载,实现了有参、无参、参数的Get请求

    通过对此分析,我们模拟一个自定义的Controller来实现接口的数据请求
    首先在Models中新建一个Student.cs

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    
    namespace WebApi.Models
    {
        public class Student
        {
            public int Id { get; set; }
            public string Name { get; set; }
        }
    }
    

    然后在Controller右键-添加-控制器-Web Api-Web Api2 控制器-空

    image.png

    命名为StudentsController,注意Controller一定不要省略,否则接口无法生效

    StudentsController编写如下代码

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    using WebApi.Models;
    
    namespace WebApi.Controllers
    {
        public class StudentsController : ApiController
        {
            public Student Get()
            {
                return new Student(){Id = 1,Name = "kysin"}
            }
        }
    }
    

    可以看到返回了一个对象,而数组的内容就是我们return出去的这个Student对象
    用postman测试请求

    如果想返回一个数组怎么办呢
    编写如下代码

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    using WebApi.Models;
    
    namespace WebApi.Controllers
    {
        public class StudentsController : ApiController
        {
            public List<Student> Get()
            {
                return new List<Student>()
                { 
                    new Student() { Id = 1, Name = "kysin1" },
                    new Student() { Id = 2, Name = "kysin2" },
                    new Student() { Id = 3, Name = "kysin3" },
                    new Student() { Id = 4, Name = "kysin4" },
                    new Student() { Id = 5, Name = "kysin5" }
                };
            }
    }
    

    用postman测试请求可以看到返回了一个数组,而数组的内容就是我们return出去的这个List集合

    继续编写StudentsController

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    using WebApi.Models;
    
    namespace WebApi.Controllers
    {
        public class StudentsController : ApiController
        {
            public string GetName(string name)
            {
                return "你传入的参数是" + name;
            }
            public string GetAddress(string address)
            {
                return "你传入的地址是" + address;
            }
        }
    }
    

    分别用postman测试

    如果我们去掉这个Get前缀呢

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    using WebApi.Models;
    
    namespace WebApi.Controllers
    {
        public class StudentsController : ApiController
        {
            public string Address(string address)
            {
                return "你传入的地址是" + address;
            }
        }
    }
    

    因此可以看到,WebApi通过Get前缀的方式进行http请求的类型识别,这种必须以get、post、delet、put等前缀方式请求格式为restful方式

    参数传递分析

    Get的参数传递

    在http中,以get方式请求的参数实际上是通过url后面拼接参数的键名=键值来完成传递的,那么在webapi中就对应请求的参数就是通过方法的参数来自动进行获取

    但是对于body而言,数据既可以放在url里面拼接,也可以放在body中进行传递,那么在webapi中我们应该如何进行代码编写呢

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    using WebApi.Models;
    
    namespace WebApi.Controllers
    {
        public class StudentsController : ApiController
        {
            public void Post(Student stu)
            {
                return "成功"
            }
        }
    }
    

    相关文章

      网友评论

          本文标题:WebApi入门

          本文链接:https://www.haomeiwen.com/subject/cdsyvltx.html