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

相关推荐
ai_xiaogui1 小时前
PanelAI应用市场跑通!一键部署容器 + 服务器迁移宝塔面板安装全记录
服务器·宝塔面板安装教程2026·服务器重装系统迁移·panelai应用市场·轻量服务器优化swap·ai项目一键部署·panelai部署容器
lwprain1 小时前
Umi-ocr2.1.5的linux部署,仅做记录
linux·服务器·umi-ocr
cjp5602 小时前
002.WEB API 服务器 RESTful规范
服务器
卧室小白2 小时前
K8S-Pod基本配置
linux·运维·服务器
yyuuuzz2 小时前
谷歌云基础服务的入门认知
linux·运维·服务器·数据库·人工智能·github
syagain_zsx2 小时前
Linux进程全面解析:从基础到高级管理(2/3)
linux·运维·服务器
洛水水2 小时前
图床项目实现:MD5秒传 + 个人文件列表 + 图片分享等功能的完善
服务器·网络
爱吃泡芙的小白白3 小时前
无人机机巢:低空经济的自动化基石,一文读懂其原理、应用与未来
运维·自动化·无人机·低空经济
翼龙云_cloud3 小时前
阿里云代理商:轻量服务器建站常见问题及解决方案汇总
运维·阿里云·云计算