如何从WCF服务返回干净的JSON?

我想从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? 谢谢!

将GetResults的返回types更改为List<Person>
消除用于将List序列化为jsonstring的代码 – WCF会自动为您执行此操作。

使用Person类的定义,这段代码适用于我:

 public List<Person> GetPlayers() { List<Person> players = new List<Person>(); players.Add(new Person { FirstName="Peyton", LastName="Manning", Age=35 } ); players.Add(new Person { FirstName="Drew", LastName="Brees", Age=31 } ); players.Add(new Person { FirstName="Brett", LastName="Favre", Age=58 } ); return players; } 

结果:

 [{"Age":35,"FirstName":"Peyton","LastName":"Manning"}, {"Age":31,"FirstName":"Drew","LastName":"Brees"}, {"Age":58,"FirstName":"Brett","LastName":"Favre"}] 

(全部在一条线上)

我也在这个方法上使用了这个属性:

 [WebInvoke(Method = "GET", RequestFormat = WebMessageFormat.Json, ResponseFormat = WebMessageFormat.Json, UriTemplate = "players")] 

Method =“GET”的WebInvoke与WebGet相同,但由于我的一些方法是POST,所以我使用所有的WebInvoke来保持一致性。

UriTemplate设置方法可用的URL。 所以我可以在http://myserver/myvdir/JsonService.svc/players上做一个GET,它只是起作用。

另外检查IIRF或另一个URL重写器来摆脱URI中的.svc。

如果你想在你的服务类中没有硬编码属性,

在你的行为configuration中使用<webHttp defaultOutgoingResponseFormat="Json"/>

这是在web.config中为您的web服务完成的。 将bindingBehavior设置为<webHttp>,您将看到干净的JSON。 额外的“[d]”由您需要覆盖的默认行为设置。

另外看这个博客: http : //blog.clauskonrad.net/2010/11/how-to-expose-json-endpoint-from-wcf.html

我遇到了同样的问题,并通过将BodyStyle属性值更改为“WebMessageBodyStyle.Bare”来解决此问题:

 [OperationContract] [WebGet(BodyStyle = WebMessageBodyStyle.Bare, RequestFormat = WebMessageFormat.Json, ResponseFormat = WebMessageFormat.Json, UriTemplate = "GetProjectWithGeocodings/{projectId}")] GeoCod_Project GetProjectWithGeocodings(string projectId); 

返回的对象将不再被包装。

当你使用GET方法时,合约必须是这个。

 [WebGet(UriTemplate = "/", BodyStyle = WebMessageBodyStyle.Bare, ResponseFormat = WebMessageFormat.Json)] List<User> Get(); 

有了这个,我们有一个没有启动参数的JSON

阿尔多·弗洛雷斯@alduar http://alduar.blogspot.com

在您的IServece.cs中添加以下标记:BodyStyle = WebMessageBodyStyle.Bare

  [WebInvoke(Method = "GET", ResponseFormat = WebMessageFormat.Json, BodyStyle = WebMessageBodyStyle.Bare, UriTemplate = "Getperson/{id}")] List<personClass> Getperson(string id);