文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

从初学者到专家:ASP.NET RESTful 服务开发教程

2024-02-05 00:07

关注

1. 概述

REST(Representational State Transfer)是一种软件架构风格,它允许应用程序通过 HTTP 请求来创建、读取、更新和删除数据。RESTful 服务是一种遵循 REST 架构风格的 Web 服务,它允许应用程序通过 HTTP 请求来操作数据,而无需考虑数据的存储结构和访问方式。

2. 创建 ASP.NET RESTful 服务

创建一个 ASP.NET RESTful 服务非常简单,只需要在项目中安装 Microsoft.AspNetCore.Mvc.WebApiCompatShim 包,然后在项目中创建 Web API 控制器即可。

Install-Package Microsoft.AspNetCore.Mvc.WebApiCompatShim
public class ProductsController : Controller
{
    private readonly IProductsRepository _productsRepository;

    public ProductsController(IProductsRepository productsRepository)
    {
        _productsRepository = productsRepository;
    }

    [HttpGet]
    public IEnumerable<Product> GetProducts()
    {
        return _productsRepository.GetAll();
    }

    [HttpGet("{id}")]
    public Product GetProduct(int id)
    {
        return _productsRepository.GetById(id);
    }

    [HttpPost]
    public Product CreateProduct([FromBody] Product product)
    {
        return _productsRepository.Create(product);
    }

    [HttpPut("{id}")]
    public Product UpdateProduct(int id, [FromBody] Product product)
    {
        return _productsRepository.Update(id, product);
    }

    [HttpDelete("{id}")]
    public void DeleteProduct(int id)
    {
        _productsRepository.Delete(id);
    }
}

3. 处理 HTTP 请求和响应

ASP.NET RESTful 服务可以通过重写 Web API 控制器中的方法来处理 HTTP 请求和响应。

public class ProductsController : Controller
{
    private readonly IProductsRepository _productsRepository;

    public ProductsController(IProductsRepository productsRepository)
    {
        _productsRepository = productsRepository;
    }

    [HttpGet]
    public IEnumerable<Product> GetProducts()
    {
        return _productsRepository.GetAll();
    }

    [HttpPost]
    public Product CreateProduct([FromBody] Product product)
    {
        return _productsRepository.Create(product);
    }

    [HttpPut("{id}")]
    public Product UpdateProduct(int id, [FromBody] Product product)
    {
        return _productsRepository.Update(id, product);
    }

    [HttpDelete("{id}")]
    public void DeleteProduct(int id)
    {
        _productsRepository.Delete(id);
    }

    protected override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        // Handle HTTP Request
        if (filterContext.HttpContext.Request.Method == "OPTIONS")
        {
            filterContext.HttpContext.Response.Headers.Add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");
            filterContext.HttpContext.Response.Headers.Add("Access-Control-Allow-Headers", "Content-Type, Authorization");
            filterContext.HttpContext.Response.StatusCode = 200;
            filterContext.Result = new EmptyResult();
            return;
        }

        // Handle CORS
        if (filterContext.HttpContext.Request.Headers.ContainsKey("Origin"))
        {
            filterContext.HttpContext.Response.Headers.Add("Access-Control-Allow-Origin", "*");
        }
    }
}

4. 使用 JSON 和 XML 来格式化数据

ASP.NET RESTful 服务可以使用 JSON 和 XML 两种格式来格式化数据。

public class ProductsController : Controller
{
    private readonly IProductsRepository _productsRepository;

    public ProductsController(IProductsRepository productsRepository)
    {
        _productsRepository = productsRepository;
    }

    [HttpGet]
    public IEnumerable<Product> GetProducts()
    {
        return _productsRepository.GetAll();
    }

    [HttpPost]
    public Product CreateProduct([FromBody] Product product)
    {
        return _productsRepository.Create(product);
    }

    [HttpPut("{id}")]
    public Product UpdateProduct(int id, [FromBody] Product product)
    {
        return _productsRepository.Update(id, product);
    }

    [HttpDelete("{id}")]
    public void DeleteProduct(int id)
    {
        _productsRepository.Delete(id);
    }

    protected override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        // Handle HTTP Request
        if (filterContext.HttpContext.Request.Method == "OPTIONS")
        {
            filterContext.HttpContext.Response.Headers.Add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");
            filterContext.HttpContext.Response.Headers.Add("Access-Control-Allow-Headers", "Content-Type, Authorization");
            filterContext.HttpContext.Response.StatusCode = 200;
            filterContext.Result = new EmptyResult();
            return;
        }

        // Handle CORS
        if (filterContext.HttpContext.Request.Headers.ContainsKey("Origin"))
        {
            filterContext.HttpContext.Response.Headers.Add("Access-Control-Allow-Origin", "*");
        }

        // Handle JSON and XML Serialization
        var requestContentType = filterContext.HttpContext.Request.ContentType;
        if (requestContentType != null && requestContentType.Contains("application/json"))
        {
            filterContext.HttpContext.Request.ContentType = "application/json; charset=utf-8";
        }
        else if (requestContentType != null && requestContentType.Contains("application/xml"))
        {
            filterContext.HttpContext.Request.ContentType = "application/xml; charset=utf-8";
        }
    }
}

5. 使用 Swagger 来生成 API 文档

Swagger 是一种用于生成 API 文档的工具,它可以帮助开发人员快速了解和使用 API 的功能。

Install-Package Swashbuckle.AspNetCore
public class Startup
{
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddSwaggerGen(c =>
        {
            c.SwaggerDoc("v1", new OpenApiInfo { Title = "Products API", Version = "v1" });
        });
    }

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        app.UseSwagger();
        app.UseSwaggerUI(c =>
        {
            c.SwaggerEndpoint("/swagger/v1/swagger.json", "Products API V1");
        });
    }
}

6. 部署 RESTful 服务

ASP.NET RESTful 服务可以通过各种方式部署,包括在 IIS 上部署、在容器中部署、在云平台上部署等。

dotnet publish -c Release

7. 使用 Postman 来测试 RESTful 服务

Postman 是一款强大的 API 测试工具,它可以帮助开发人员快速测试和调试 API 的功能。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯