首先在Program.cs中添加AddxmlSerializerFormatters()以启用XML支持,接着定义公共模型类并确保属性具有getter/setter;控制器使用Ok结果返回对象,框架根据Accept头自动选择JSON或XML格式;若需强制返回XML,可手动使用XmlSerializer序列化并返回ContentResult,设置ContentType为application/xml;注意XML序列化不支持复杂类型或循环引用,且性能较json差,应按需启用。

在 ASP.net Core 中返回 XML 格式的 API 响应,需要配置 mvc 以支持 XML 序列化,并使用相应的结果类型。默认情况下,ASP.NET Core 只支持 JSON,但可以通过添加内置的 XML 输出格式器来启用 XML 支持。
1. 启用 XML 格式支持
在 Program.cs 或 Startup.cs(取决于项目结构)中,需要向 MVC 配置添加 XML 序列化支持:
builder.Services.AddControllers()
.AddXmlSerializerFormatters(); // 支持 application/xml
这行代码会注册 XmlSerializer 格式器,使控制器能够根据请求头中的 Accept: application/xml 返回 XML 数据。
2. 控制器中返回 XML 数据
定义一个简单的模型类:
{
public int Id { get; set; }
public String Name { get; set; }
}
在控制器中返回该对象:
[ApiController]
[Route(“[controller]”)]
public class PeopleController : ControllerBase
{
[httpGet(“{id}”)]
public IActionResult Get(int id)
{
var person = new Person { Id = id, Name = “张三” };
return Ok(person); // 自动根据 Accept 头选择格式
}
}
当客户端请求时设置 Accept: application/xml,API 就会返回 XML 格式内容:
<Person xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance” xmlns:xsd=”http://www.w3.org/2001/XMLSchema”>
<Id>1</Id>
<Name>张三</Name>
</Person>
3. 强制返回 XML(忽略请求头)
如果想无论请求头如何都返回 XML,可以使用 ContentResult 手动序列化:
using System.Xml.Serialization;
using System.IO;
// …
[HttpGet(“xml/{id}”)]
public ContentResult GetXml(int id)
{
var person = new Person { Id = id, Name = “李四” };
var serializer = new XmlSerializer(typeof(Person));
using var writer = new StringWriter();
serializer.Serialize(writer, person);
return new ContentResult
{
ContentType = “application/xml”,
Content = writer.ToString(),
StatusCode = 200
};
}
4. 注意事项
- 确保类和属性是公共的,且具有 getter/setter,否则 XmlSerializer 无法序列化
- 不支持复杂类型或循环引用,如需更灵活控制可考虑使用 DataContractSerializer
- 若同时支持 JSON 和 XML,客户端通过 Accept 头决定返回格式
- 性能上 XML 比 JSON 稍慢,体积更大,按需启用
基本上就这些。只要注册了 XML 格式器,ASP.NET Core 就能自动处理内容协商,返回正确的 XML 响应。


