c# .net4.6.1 mvc控制器xml数据,给出范例
时间: 2024-11-27 20:14:23 浏览: 27
在C# .NET 4.6.1 MVC(模型-视图-控制器)中,XML数据通常用于序列化或反序列化操作,特别是在Web API控制器中处理HTTP请求时。当你需要传递或接收XML格式的数据,可以使用`System.Xml.Linq`命名空间中的类如`XDocument`或`XElement`。
以下是一个简单的例子,演示如何创建一个控制器来接受XML POST请求并将其解析为`XDocument`:
```csharp
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Web.Mvc;
using System.Xml.Linq;
[RoutePrefix("api/[controller]")]
public class ValuesController : Controller
{
[HttpPost, Route("")]
public ActionResult Create([FromBody] XElement xmlData)
{
// 检查请求是否有效
if (xmlData == null || !xmlData.Any())
{
return BadRequest("Invalid XML data.");
}
// 解析XML数据
var xmlDoc = XElement.Parse(xmlData.ToString());
// 进行必要的处理,比如验证数据结构、提取信息等
// 假设我们只是简单地返回XML数据
string resultXml = xmlDoc.ToString();
return Content(resultXml, "application/xml");
}
}
```
在这个例子中,当POST到`/api/values`时,XML数据会被自动绑定到`XElement xmlData`参数上。你可以根据需要对`xmlData`进行遍历和操作。
对于发送XML数据的情况,你可能需要创建一个`XDocument`实例,然后用`ContentResult`或`JsonResult`包装它,设置正确的`Content-Type`为`application/xml`:
```csharp
[HttpGet]
public ActionResult GetXml()
{
// 创建XML数据
XDocument xmlDoc = new XDocument(
new XElement("Root",
new XElement("Item1", "Value1"),
new XElement("Item2", "Value2")
)
);
return Content(xmlDoc.ToString(), "application/xml");
}
```
这将返回一个包含指定XML内容的结果。
阅读全文