Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/311.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# WebApi中带有自定义负载的HttpError_C#_.net_Xml_Asp.net Web Api - Fatal编程技术网

C# WebApi中带有自定义负载的HttpError

C# WebApi中带有自定义负载的HttpError,c#,.net,xml,asp.net-web-api,C#,.net,Xml,Asp.net Web Api,我试图找到一种使用ASP.NET WebApi返回自定义负载的方法,该方法使用非200返回代码。基本上我想要 {"status":{"code":"40001", "message": "Field XXX can not be empty"}} 及 我正在使用HttpError类,通过添加Dictionary和所需的负载来实现。它非常适合JSON,但不适合XML,据我所知,它归结为XmlSerializer和HttpError没有很好地发挥作用 下面是一个简短的代码片段,用于重现完全相同的错

我试图找到一种使用ASP.NET WebApi返回自定义负载的方法,该方法使用非200返回代码。基本上我想要

{"status":{"code":"40001", "message": "Field XXX can not be empty"}}

我正在使用
HttpError
类,通过添加
Dictionary
和所需的负载来实现。它非常适合JSON,但不适合XML,据我所知,它归结为
XmlSerializer
HttpError
没有很好地发挥作用

下面是一个简短的代码片段,用于重现完全相同的错误:

var error = new HttpError();
var status = new Dictionary<string, string>
{
    {"code", "40001"},
    {"text", "Field XXX can not be empty"}
};
error.Add("status", status);
var ser = new XmlSerializer(error.GetType());
StringWriter strWriter = new StringWriter();
ser.Serialize(strWriter, error);
它本身可以很好地序列化,但如果在HttpError中使用,则会引发非常相同的异常:
Xml-type“xdt:untypedAtomic列表”不支持从Clr类型“ResponseStatus”到Clr类型“String”的转换。


我不相信以前没有人这样做过,所以我想知道我错过了什么?

你也可以这样做

HttpError err = new HttpError();
err["code"] = "40001";
err["text"] = "Field XXX can not be empty";
然后通过控制器级别的HttpResponseMessage返回它

return Request.CreateResponse(HttpStatusCode.--, err);
要返回{“status”:{“code”:“40001”,“message”:“Field XXX不能为空”},您可能必须创建一个复杂类型ie

public class ResponseStatus
{
    public Status status { get; set; }
}

public class Status
{
     public string code { get; set; }
     public string message { get; set; }
}
然后实例化控制器ie中的两个类

Status st = new Status();
st.code = "40001";
st.message = "Field XXX can not be empty";

ResponseStatus responsStatus = new ResponseStatus();
responsStatus.status = st;
return Request.CreateResponse(HttpStatusCode.OK, responsStatus);
<>为了更好地控制输出,考虑用属性和属性来装饰类。从这些名称空间System.ComponentModel.DataAnnotations并使用System.Runtime.ie

[DataContract]
class Status
{
      [DataMember(Name = "code")]
      public string code { get; set; }
      [DataMember(Name = "message")]
      public string message { get; set; }
}

好的,我修改了最初的问题。序列化字符串是可行的,但我需要将这些键包装在“status”字段中。在这种情况下,序列化失败
Status st = new Status();
st.code = "40001";
st.message = "Field XXX can not be empty";

ResponseStatus responsStatus = new ResponseStatus();
responsStatus.status = st;
return Request.CreateResponse(HttpStatusCode.OK, responsStatus);
[DataContract]
class Status
{
      [DataMember(Name = "code")]
      public string code { get; set; }
      [DataMember(Name = "message")]
      public string message { get; set; }
}