【发布时间】:2011-01-06 09:33:24
【问题描述】:
我正在尝试从 WCF 服务返回一些 JSON。该服务只是从我的数据库中返回一些内容。我可以得到数据。但是,我担心 JSON 的格式。目前,返回的 JSON 格式如下:
{"d":"[{\"Age\":35,\"FirstName\":\"Peyton\",\"LastName\":\"Manning\"},{\"Age\":31,\"FirstName\":\"Drew\",\"LastName\":\"Brees\"},{\"Age\":29,\"FirstName\":\"Tony\",\"LastName\":\"Romo\"}]"}
实际上,我希望我的 JSON 格式尽可能干净。我相信(我可能不正确),以干净的 JSON 表示的相同结果集合应该如下所示:
[{
"Age": 35,
"FirstName": "Peyton",
"LastName": "Manning"
}, {
"Age": 31,
"FirstName": "Drew",
"LastName": "Brees"
}, {
"Age": 29,
"FirstName": "Tony",
"LastName": "Romo"
}]
我不知道“d”是从哪里来的。我也不知道为什么要插入转义字符。我的实体如下所示:
[DataContract]
public class Person
{
[DataMember]
public string FirstName { get; set; }
[DataMember]
public string LastName { get; set; }
[DataMember]
public int Age { get; set; }
public Person(string firstName, string lastName, int age)
{
this.FirstName = firstName;
this.LastName = lastName;
this.Age = age;
}
}
负责返回内容的服务定义为:
[ServiceContract(Namespace = "")]
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
public class TestService
{
[OperationContract]
[WebGet(ResponseFormat = WebMessageFormat.Json)]
public string GetResults()
{
List<Person> results = new List<Person>();
results.Add(new Person("Peyton", "Manning", 35));
results.Add(new Person("Drew", "Brees", 31));
results.Add(new Person("Tony", "Romo", 29));
// Serialize the results as JSON
DataContractJsonSerializer serializer = new DataContractJsonSerializer(results.GetType());
MemoryStream memoryStream = new MemoryStream();
serializer.WriteObject(memoryStream, results);
// Return the results serialized as JSON
string json = Encoding.Default.GetString(memoryStream.ToArray());
return json;
}
}
如何从 WCF 服务返回“干净”的 JSON? 谢谢!
【问题讨论】:
-
SOAP 应该返回 XML。您可以使用 REST 端点返回 JSON。看看stackoverflow.com/questions/186631/…
-
顺便说一句,如果其他人遇到这个并想知道为什么“d”属性在那里,它可以修补JSON vulnerability。删除它会让你再次变得脆弱。
-
@Alex - 漏洞取决于重新定义 Array 对象,这在现代浏览器中不再可能。见stackoverflow.com/questions/16289894/…
-
那很好。 :) 我的答案有一半仍然是正确的——它在那里修补了那个漏洞。