ASP.NET Core如何返回XML格式的API响应

来源:IT编程作者:坚哥头衔:草根站长
导读:本期聚焦于小伙伴创作的《ASP.NET Core如何返回XML格式的API响应》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《ASP.NET Core如何返回XML格式的API响应》有用,将其分享出去将是对创作者最好的鼓励。

在ASP.NET Core的API开发中,默认情况下接口返回的是JSON格式的数据,但部分业务场景需要接口返回XML格式响应,比如对接旧系统、满足特定客户端的格式要求等。要实现XML格式的API响应,需要对项目的格式化器进行配置,同时了解请求和响应的相关处理规则。

ASP.NET Core如何返回XML格式的API响应

添加XML格式化器

ASP.NET Core默认没有启用XML格式化功能,需要手动添加对应的NuGet包并配置服务。首先要在项目中安装Microsoft.AspNetCore.Mvc.Formatters.Xml包,安装完成后在Program.cs中配置MVC服务时添加XML格式化器。

以下是基础配置代码示例:

// Program.cs 中的服务配置部分
var builder = WebApplication.CreateBuilder(args);

// 添加控制器服务,并配置XML格式化器
builder.Services.AddControllers()
    .AddXmlSerializerFormatters(); // 添加基于XmlSerializer的XML格式化器

var app = builder.Build();

// 启用路由和控制器
app.MapControllers();

app.Run();

这里添加的AddXmlSerializerFormatters方法会使用XmlSerializer来序列化对象为XML格式,如果需要使用DataContractSerializer,可以替换为AddXmlDataContractSerializerFormatters方法。

定义返回XML的API接口

配置完成XML格式化器后,接口可以直接返回对象,框架会根据请求的Accept头自动选择返回格式。如果需要强制返回XML格式,也可以通过指定Produces特性来实现。

自动根据请求头返回格式

当客户端请求的Accept头包含application/xml时,接口会自动返回XML格式数据,否则返回默认的JSON格式。以下是示例接口代码:

using Microsoft.AspNetCore.Mvc;

[ApiController]
[Route("api/[controller]")]
public class UserController : ControllerBase
{
    [HttpGet("{id}")]
    public IActionResult GetUser(int id)
    {
        var user = new User
        {
            Id = id,
            Name = "张三",
            Age = 25,
            Email = "test@ipipp.com"
        };
        return Ok(user);
    }
}

// 定义用户实体类
public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int Age { get; set; }
    public string Email { get; set; }
}

当使用PostMan等工具请求api/user/1,并在请求头中设置Accept: application/xml时,返回的内容如下:

<?xml version="1.0" encoding="utf-8"?>
<User xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <Id>1</Id>
  <Name>张三</Name>
  <Age>25</Age>
  <Email>test@ipipp.com</Email>
</User>

强制返回XML格式

如果希望某个接口无论请求头如何都返回XML格式,可以在接口方法或者控制器上添加[Produces("application/xml")]特性:

[ApiController]
[Route("api/[controller]")]
[Produces("application/xml")] // 整个控制器下的接口都默认返回XML
public class ProductController : ControllerBase
{
    [HttpGet]
    public IActionResult GetProducts()
    {
        var products = new List<Product>
        {
            new Product { Id = 1, Name = "产品A", Price = 100 },
            new Product { Id = 2, Name = "产品B", Price = 200 }
        };
        return Ok(products);
    }
}

public class Product
{
    public int Id { get; set; }
    public string Name { get; set; }
    public decimal Price { get; set; }
}

处理XML序列化的自定义需求

默认的XML序列化可能无法满足所有需求,比如需要自定义节点名称、忽略某些属性、设置命名空间等,可以通过在实体类上添加XML相关的特性来实现。

以下是自定义XML序列化的实体类示例:

using System.Xml.Serialization;

[XmlRoot("UserInfo")] // 自定义根节点名称
public class CustomUser
{
    [XmlAttribute("UserId")] // 将Id作为根节点的属性
    public int Id { get; set; }

    [XmlElement("UserName")] // 自定义属性对应的节点名称
    public string Name { get; set; }

    [XmlIgnore] // 忽略该属性,不序列化到XML中
    public int Age { get; set; }

    public string Email { get; set; }
}

使用该实体类返回XML时,序列化结果会按照特性配置生成,比如Id会成为根节点的属性,Name对应的节点名变为UserName,Age属性不会出现在XML中。

注意事项

  • 如果同时添加了JSON和XML格式化器,框架会根据请求的Accept头优先级选择返回格式,当Accept头同时包含两种格式时,默认优先返回JSON。
  • 使用AddXmlSerializerFormatters时,实体类的属性需要有公共的get和set访问器,否则无法正确序列化。
  • 如果需要返回自定义的XML字符串,可以直接返回Content结果,指定内容类型为application/xml
[HttpGet("custom-xml")]
public IActionResult GetCustomXml()
{
    string xmlContent = "<?xml version="1.0" encoding="utf-8"?><Result><Code>200</Code><Message>操作成功</Message></Result>";
    return Content(xmlContent, "application/xml");
}

这种方式适合需要完全自定义XML结构的场景,不需要依赖实体类的序列化规则。

ASP.NET_CoreXMLAPI响应格式化器修改时间:2026-06-17 19:54:41

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。