第一节-简单的webapi接
开发环境
Visual Studio 2019
.net core 3.0
打开vs2019新建项目
具体步骤如下图:
此处我们选择API(新手不推荐选择空项目,选择API系统会为我们自动创建WebApi需要的一些配置文件等),Https配置这一项我们暂时不勾选,目前我们不配置Https。
点创建以后的界面如下图:
运行项目
F5运行项目,然后就可以看到微软为我们写好的一个天气预报示例webapi了,这里只有一个Get请求示例,返回值为json格式。
Startup.cs说明
注意:services.AddControllers();
和 endpoints.MapControllers();
方法成对出现, 这是.net core3.0中的最新写法
ConfigureServices方法
用来向容器中注册服务,注册好的服务可以在其他地方进行调用.
Configure方法
用来配置中间件管道,即如何响应http请求.
创建第一个Controller
1 右键删除系统默认创建的WeatherForecastController.cs
和WeatherForecast.cs
2 新建一个控制器,命名:UserController.cs
新建以后如下图:
注:我们打开项目依赖项,可以看到系统默认给我们增加了EntiyFrameworkCore
的引用,由此就可以看出微软也在大力推广EF的使用了。
回归正题,我们在UserController
中增加一个Login
的get
方式的接口方法,返回一个hello
,我们打算通过请求api/User/Login
来得到这个hello
,F5运行程序
namespace XXX.api.Controllers
{
[Route("api/[controller]")]
[ApiController]
public class UserController : ControllerBase
{
[HttpGet]
public IActionResult Login()
{
return Ok("hello");
}
}
}
问题来了,为啥直接给打开weatherforecast
,而且还404了,别急,往下看。
在项目Properties
中打开launchsettings.json
。
修改launchsettings.json
,我们删掉了关于IIS相关的内容(让webapi不通过IIS来加载),然后修改了lauchUrl
属性,如下:
{
"profiles": {
"XXX.api": {
"commandName": "Project",
"launchBrowser": true,
"launchUrl": "api/User/Login",
"applicationUrl": "http://localhost:5000/",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
}
}
(┬_┬)怎么还是404?别急继续往下看
因为我们是要通过api/User/Login
来得到这个hello
,所以我们要在UserController
里定义一个action
的动作,这样才能通过api/User/Login
来得到这个hello
,如下图新增action
F5运行结果如下:
增加全局路由
上面增加action
虽然能达到想要的结果,但是每次新建一个Controller
都有写个action
万一要是忘记了又要忙乎半天,有没有一劳永逸的办法呢?
继续往下看:
1.首先去掉Controller里的Route
和ApiController
2.修改Startup.cs
,增加路由模版:
感觉每次还是删除两段代码还是有点麻烦,虽然麻烦,但是用全局路由可以方便后期更改,万一老板不想通过api/xxx/xxx的方式来访问接口,想通过api2/xxx/xxx的方式访问,此时你只需要修改下Startup.cs
即可。
今天就介绍到这里,后续会继续更新,如需要源代码的请联系本人,加微信号:18700482809