栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

添加ASP.NET Core Web API数据存储(Models,Services)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

添加ASP.NET Core Web API数据存储(Models,Services)

创建模型

模型包含用于表示特征的属性。 模型用于在 Web API 中传递数据,以及在数据存储中保存选项。

在这里,该数据存储是一个简单的本地内存中缓存服务。 在实际应用程序中,可以考虑将数据库(例如 SQL Server)与 Entity Framework Core 结合使用。

运行以下命令以创建 Models 文件夹:

mkdir Models

在 Visual Studio Code 中选择 Models 文件夹,并添加名为 Pizza.cs 的新文件。

项目根目录现在包含一个带有空 Pizza.cs 文件的 Models 目录。 目录名称 Models 是一种约定。 目录名称来自 Web API 使用的模型-视图-控制器体系结构。

将以下代码添加到 Models/Pizza.cs 。 保存更改。

namespace ContosoPizza.Models;

public class Pizza
{
    public int Id { get; set; }
    public string? Name { get; set; }
    public bool IsGlutenFree { get; set; }
}
添加数据服务

运行以下命令以创建 Services 文件夹:

mkdir Services

在 Visual Studio Code 中选择该文件夹,并添加名为 PizzaService.cs 的新文件。

将以下代码添加到 Services/PizzaService.cs,以创建内存中披萨数据服务。 保存所做更改。

using ContosoPizza.Models;

namespace ContosoPizza.Services;

public static class PizzaService
{
    static List Pizzas { get; }
    static int nextId = 3;
    static PizzaService()
    {
        Pizzas = new List
        {
            new Pizza { Id = 1, Name = "Classic Italian", IsGlutenFree = false },
            new Pizza { Id = 2, Name = "Veggie", IsGlutenFree = true }
        };
    }

    public static List GetAll() => Pizzas;

    public static Pizza? Get(int id) => Pizzas.FirstOrDefault(p => p.Id == id);

    public static void Add(Pizza pizza)
    {
        pizza.Id = nextId++;
        Pizzas.Add(pizza);
    }

    public static void Delete(int id)
    {
        var pizza = Get(id);
        if(pizza is null)
            return;

        Pizzas.Remove(pizza);
    }

    public static void Update(Pizza pizza)
    {
        var index = Pizzas.FindIndex(p => p.Id == pizza.Id);
        if(index == -1)
            return;

        Pizzas[index] = pizza;
    }
}

默认情况下,此服务提供一个简单的内存中数据缓存服务,其中包含两个数据。 我们的 Web API 将使用该服务进行演示。 如果先停止再启动 Web API,内存中数据缓存将重置为 PizzaService 的构造函数中的两个默认数据。

生成 Web API 项目

运行以下命令以生成应用:

dotnet build

生成成功,且没有任何警告。 如果生成失败,请检查输出以获取故障排除信息。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/837751.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号