WebApi实质上是进行数据处理和返回的一个服务,在前后分离的工程中起着关键性的桥梁作用
新建WebApi工程
打开visual studio,ctrl+shift+N
新建WebApi项目
data:image/s3,"s3://crabby-images/aae3d/aae3d1d558845f4047d58186410baacc39c60e78" alt=""
data:image/s3,"s3://crabby-images/cef22/cef22f489fe427fc5c7a2e3a90b3bdfa4f8f1cc2" alt=""
新建一个空项目,先不要勾选 为HTTPS位置
data:image/s3,"s3://crabby-images/b4ce6/b4ce609e933eac4c9fedee2cdd3a0e0eb09ee5bd" alt=""
在vs给我们创建的工程项目中,HomeController
实际上是MVC模块的Controller
data:image/s3,"s3://crabby-images/7fbd4/7fbd4c41fd7a35a3862154bd3845fa564e8ed23a" alt=""
而ApiController
才是我们所需要进行业务开发的地方
data:image/s3,"s3://crabby-images/c603d/c603d1b946805d4310e1f60da8168a787fcec2eb" alt=""
F10运行项目,会看到WebApi的Home Page页面,里面展示了一系列的向导
data:image/s3,"s3://crabby-images/46735/4673531857fda8d4e339effdc1ce9c4732cad442" alt=""
在浏览器地址输入http://localhost:61035/api/result
,会发现,页面返回了一个XML
data:image/s3,"s3://crabby-images/f5b71/f5b710893f35f5a478b43e3e1ea49f99de5a9db9" alt=""
但是我们在实际的业务开发中,都是用的JSON格式的数据,那么我们用postman访问这个地址试试
data:image/s3,"s3://crabby-images/539fa/539fa8ff639376021558ecad854c2c9857903d81" alt=""
会发现接口返回的是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 控制器-空
data:image/s3,"s3://crabby-images/3403a/3403a4dd72733e038c226e870d5e6a21003432ac" alt=""
命名为StudentsController
,注意Controller
一定不要省略,否则接口无法生效
data:image/s3,"s3://crabby-images/b2ccd/b2ccd9bce94d6b631938ed493c941802f637077d" alt=""
在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测试请求
data:image/s3,"s3://crabby-images/d19ca/d19ca1196864e1fa239d44fe0383ea1bc1cc1a74" alt=""
如果想返回一个数组怎么办呢
编写如下代码
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" }
};
}
}
data:image/s3,"s3://crabby-images/afbed/afbed1ac6b5ee6a7de3b93e1ec2f33e7df625250" alt=""
用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测试
data:image/s3,"s3://crabby-images/1c63f/1c63ff4a3cc3cb7b81bdbff148d5ae2d9c77210f" alt=""
data:image/s3,"s3://crabby-images/f1b2c/f1b2c5f32a38891ba5a112f93b86707251c0e3a8" alt=""
如果我们去掉这个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;
}
}
}
data:image/s3,"s3://crabby-images/317ce/317ce27b682cdfc550da15dcf2e5b0e5fd35c33c" alt=""
因此可以看到,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 "成功"
}
}
}
data:image/s3,"s3://crabby-images/c2c9d/c2c9d080cc2dcba97fe63520a8cb443d0d9c36b4" alt=""
网友评论