001.Web Api_服务器,新建api

一.首先先建立一个HelloWorld的专案

1.控制器文件夹Controllers

所有的控制器都应统一放在Controllers资料夹下,命名规则会使用名称Controller,就像范例的WeatherForecastController.cs,会以Controller做结尾,.net会自动判断结尾为Controller一个控制器,Controller只是标签,他会自动去掉标签,是这支API的网址就会是/WeatherForecast。

那其实创好的专案就可以马上执行,执行的就是预设就有的WeatherForecastController这支API

怎么执行呢?我们按一下上方的PLAY图案的按钮

运行程序后,会有一个服务器控制台程序一直在监控端口,如下图,它告诉我们通过https或者http访问服务器时用什么端口去请求它

二.访问服务器

根据控制台提示,我们https访问这个服务器时,用控制台提示的

路由+控制器名

可访问到服务器这个api,路由如下,这是一个本机虚拟路由,实际配置到云服务器时,路由在后面章节讲解

localhost:7253/WeatherForecasthttps://localhost:7253/WeatherForecast用浏览器服务上面的服务器api,得到服务器回应如下:

我们再试试http访问服务器

重新用http运行程序,用服务器提示的http路由,前缀请求http,端口号改为5264

localhost:5264/WeatherForecasthttp://localhost:5264/WeatherForecast用浏览器访问后如下

两种方法都成功get到虚拟服务器了

三.新建自己的控制器

上面就是程序自带的示例控制器,程序自带示例的控制器一般都没什么用,一般会删掉要,新建自定义我们自己的控制器

1.新建控制器ESP32

在控制器文件-右键-新建项-选择包含读写功能的api控制器

新建后的控制器如下ESP32.cs

ESP32.cs

cs 复制代码
using Microsoft.AspNetCore.Mvc;

namespace Esp32_Server.Controllers
{
    [Route("api/[controller]")]
    [ApiController]
    public class ESP32 : ControllerBase
    {
        // GET: api/<ESP32>
        [HttpGet]
        public IEnumerable<string> Get()
        {
            return new string[] { "value1", "value2" };
        }

        // GET api/<ESP32>/5
        [HttpGet("{id}")]
        public string Get(int id)
        {
            return "value";
        }

        // POST api/<ESP32>
        [HttpPost]
        public void Post([FromBody] string value)
        {
        }

        // PUT api/<ESP32>/5
        [HttpPut("{id}")]
        public void Put(int id, [FromBody] string value)
        {
        }

        // DELETE api/<ESP32>/5
        [HttpDelete("{id}")]
        public void Delete(int id)
        {
        }
    }
}

1.控制器的路由配置

这是标准的路由配置,Route标签c#会自动识别这是要配置一个路由,括号内是规定的路由访问方法,

标准的方法是用api/标记+控制器名 来访问中国控制器

cs 复制代码
[Route("api/[controller]")]

这样配置的意思是,服务器默认的路由加上这个api/+控制器名可以访问到这个控制器

完整路由如下

localhost:7253/api/esp32https://localhost:7253/api/esp32

api+控制器名不分大小写,都能识别

用浏览器访问这个esp32控制器时,结果如下

我们拿到两个数据他是这个控制器get方法写好的

cs 复制代码
[HttpGet]
public IEnumerable<string> Get()
{
    return new string[] { "value1", "value2" };
}

我们把返回结果改一下,测试一下

cs 复制代码
   [HttpGet]
   public IEnumerable<string> Get()
   {
       return new string[] { "hello", "world" };
   }

再次访问api

相关推荐
乘云数字DATABUFF3 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
荣--5 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森5 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜5 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB6 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
zzzzzz3108 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode8 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220708 天前
如何搭建本地yum源(上)
运维
大树8811 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠11 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql