0

0

C#的ASP.NET Core Web API是什么?如何构建RESTful服务?

畫卷琴夢

畫卷琴夢

发布时间:2025-11-16 12:45:06

|

321人浏览过

|

来源于php中文网

原创

ASP.NET Core Web API 是基于 .NET 的高性能跨平台框架,用于构建 RESTful 服务,支持标准 HTTP 动词操作资源;通过 CLI 命令可快速创建项目,自动生成示例控制器;定义 ProductsController 实现 CRUD 操作,配合 Product 模型管理数据;集成 Swagger(Swashbuckle)提供可视化文档与测试界面;建议使用 ApiResponse 统一返回格式,提升接口规范性;后续可扩展数据库、认证、日志等机制。

c#的asp.net core web api是什么?如何构建restful服务?

C# 的 ASP.NET Core Web API 是一个用于构建高性能、跨平台 HTTP 服务的框架,特别适合创建 RESTful 风格的 Web API。它运行在 .NET 平台之上,支持 Windows、Linux 和 macOS,适用于微服务、前后端分离架构以及移动端后端等场景。

RESTful 服务基于 HTTP 协议,使用标准动词(如 GET、POST、PUT、DELETE)对资源进行操作。ASP.NET Core 提供了简洁的路由、模型绑定、序列化和中间件机制,让构建 RESTful API 变得高效且直观。

创建 ASP.NET Core Web API 项目

使用 .NET CLI 或 Visual Studio 都可以快速创建 Web API 项目。

  • 打开终端,执行命令创建新项目:
    dotnet new webapi -n MyApi
  • 进入项目目录:
    cd MyApi
  • 运行项目:
    dotnet run

默认会生成一个 Controllers/WeatherForecastController.cs 示例控制器,可通过 /weatherforecast 路由访问 JSON 数据。

定义 RESTful 控制器和路由

新建一个控制器来管理资源,比如“产品”(Product)。右键添加新类:

[ApiController]
[Route("api/[controller]")]
public class ProductsController : ControllerBase
{
    private static List _products = new()
    {
        new Product { Id = 1, Name = "笔记本电脑", Price = 5999 },
        new Product { Id = 2, Name = "鼠标", Price = 99 }
    };
[HttpGet]
public IActionResult Get() => Ok(_products);

[HttpGet("{id}")]
public IActionResult Get(int id)
{
    var product = _products.FirstOrDefault(p => p.Id == id);
    return product is null ? NotFound() : Ok(product);
}

[HttpPost]
public IActionResult Post([FromBody] Product product)
{
    product.Id = _products.Max(p => p.Id) + 1;
    _products.Add(product);
    return CreatedAtAction(nameof(Get), new { id = product.Id }, product);
}

[HttpPut("{id}")]
public IActionResult Put(int id, [FromBody] Product updatedProduct)
{
    var product = _products.FirstOrDefault(p => p.Id == id);
    if (product is null) return NotFound();

    product.Name = updatedProduct.Name;
    product.Price = updatedProduct.Price;
    return NoContent();
}

[HttpDelete("{id}")]
public IActionResult Delete(int id)
{
    var product = _products.FirstOrDefault(p => p.Id == id);
    if (product is null) return NotFound();

    _products.Remove(product);
    return NoContent();
}

}

再定义 Product 模型:

PhotoScissors
PhotoScissors

免费自动图片背景去除

下载
public class Product
{
    public int Id { get; set; }
    public string Name { get; set; } = string.Empty;
    public decimal Price { get; set; }
}

启用 Swagger 文档(API 测试与展示)

Swagger(通过 OpenAPI)能自动生成 API 文档并提供测试界面。

  • 安装 Swashbuckle 包:
    dotnet add package Swashbuckle.AspNetCore
  • Program.cs 中添加服务和中间件:
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();

// ... 其他配置

if (app.Environment.IsDevelopment()) { app.UseSwagger(); app.UseSwaggerUI(); }

启动项目后访问 /swagger,即可看到可视化 API 文档。

处理错误与返回标准格式

建议统一响应结构,例如:

public class ApiResponse
{
    public bool Success { get; set; }
    public T? Data { get; set; }
    public string? Message { get; set; }
}

在控制器中使用:

[HttpGet]
public IActionResult Get()
{
    return Ok(new ApiResponse>
    {
        Success = true,
        Data = _products
    });
}

基本上就这些。你现在已经掌握了用 C# 和 ASP.NET Core 构建 RESTful Web API 的核心流程:创建项目、定义模型、编写控制器、配置路由与文档,并返回结构化数据。后续可扩展数据库(如 Entity Framework Core)、身份认证(JWT)、日志、验证等功能。

相关专题

更多
PHP API接口开发与RESTful实践
PHP API接口开发与RESTful实践

本专题聚焦 PHP在API接口开发中的应用,系统讲解 RESTful 架构设计原则、路由处理、请求参数解析、JSON数据返回、身份验证(Token/JWT)、跨域处理以及接口调试与异常处理。通过实战案例(如用户管理系统、商品信息接口服务),帮助开发者掌握 PHP构建高效、可维护的RESTful API服务能力。

145

2025.11.26

什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

175

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

212

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

529

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

308

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

994

2023.10.19

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

150

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号