Właśnie użyłem XmlWriter, aby utworzyć XML, aby odesłać odpowiedź HTTP. Jak utworzysz ciąg JSON. Zakładam, że użyjesz konstruktora ciągów do zbudowania ciągu JSON i sformatują twoją odpowiedź jako JSON?
Właśnie użyłem XmlWriter, aby utworzyć XML, aby odesłać odpowiedź HTTP. Jak utworzysz ciąg JSON. Zakładam, że użyjesz konstruktora ciągów do zbudowania ciągu JSON i sformatują twoją odpowiedź jako JSON?
Odpowiedzi:
Możesz użyć klasy JavaScriptSerializer , sprawdź ten artykuł, aby zbudować przydatną metodę rozszerzenia.
Kod z artykułu:
namespace ExtensionMethods
{
public static class JSONHelper
{
public static string ToJSON(this object obj)
{
JavaScriptSerializer serializer = new JavaScriptSerializer();
return serializer.Serialize(obj);
}
public static string ToJSON(this object obj, int recursionDepth)
{
JavaScriptSerializer serializer = new JavaScriptSerializer();
serializer.RecursionLimit = recursionDepth;
return serializer.Serialize(obj);
}
}
}
Stosowanie:
using ExtensionMethods;
...
List<Person> people = new List<Person>{
new Person{ID = 1, FirstName = "Scott", LastName = "Gurthie"},
new Person{ID = 2, FirstName = "Bill", LastName = "Gates"}
};
string jsonString = people.ToJSON();
Korzystanie z Newtonsoft.Json sprawia, że jest to naprawdę łatwiejsze:
Product product = new Product();
product.Name = "Apple";
product.Expiry = new DateTime(2008, 12, 28);
product.Price = 3.99M;
product.Sizes = new string[] { "Small", "Medium", "Large" };
string json = JsonConvert.SerializeObject(product);
Dokumentacja: Serializacja i deserializacja JSON
string json = JsonConvert.SerializeObject(new { "PropertyA" = obj.PropertyA });.
"PropertyA"być PropertyA?
string json = JsonConvert.SerializeObject(new { PropertyA = obj.PropertyA });nie ma podwójnych cytatów naPropertyA.
Ta biblioteka jest bardzo dobra dla JSON z C #
Łatwe korzystanie z bibliotek Newtonsoft.Json i Newtonsoft.Json.Linq .
//Create my object
var my_jsondata = new
{
Host = @"sftp.myhost.gr",
UserName = "my_username",
Password = "my_password",
SourceDir = "/export/zip/mypath/",
FileName = "my_file.zip"
};
//Tranform it to Json object
string json_data = JsonConvert.SerializeObject(my_jsondata);
//Print the Json object
Console.WriteLine(json_data);
//Parse the json object
JObject json_object = JObject.Parse(json_data);
//Print the parsed Json object
Console.WriteLine((string)json_object["Host"]);
Console.WriteLine((string)json_object["UserName"]);
Console.WriteLine((string)json_object["Password"]);
Console.WriteLine((string)json_object["SourceDir"]);
Console.WriteLine((string)json_object["FileName"]);
Ten fragment kodu używa DataContractJsonSerializer z System.Runtime.Serialization.Json w .NET 3.5.
public static string ToJson<T>(/* this */ T value, Encoding encoding)
{
var serializer = new DataContractJsonSerializer(typeof(T));
using (var stream = new MemoryStream())
{
using (var writer = JsonReaderWriterFactory.CreateJsonWriter(stream, encoding))
{
serializer.WriteObject(writer, value);
}
return encoding.GetString(stream.ToArray());
}
}
Zajrzyj na stronę http://www.codeplex.com/json/, aby zapoznać się z projektem json-net.aspx. Po co ponownie wymyślać koło?
Możesz także wypróbować mój ServiceStack JsonSerializer, który jest najszybszym serializatorem .NET JSON w tej chwili. Obsługuje serializację danych, dowolnych typów POCO, interfejsów, obiektów z późnymi powiązaniami, w tym typów anonimowych itp.
Podstawowy przykład
var customer = new Customer { Name="Joe Bloggs", Age=31 };
var json = JsonSerializer.SerializeToString(customer);
var fromJson = JsonSerializer.DeserializeFromString<Customer>(json);
Uwaga: używaj Microsofts JavaScriptSerializer tylko wtedy, gdy wydajność nie jest dla Ciebie ważna, ponieważ musiałem pominąć ją w testach porównawczych, ponieważ jest do 40x-100x wolniejszy niż inne serializatory JSON.
Jeśli potrzebujesz złożonego wyniku (osadzonego), stwórz własną strukturę:
class templateRequest
{
public String[] registration_ids;
public Data data;
public class Data
{
public String message;
public String tickerText;
public String contentTitle;
public Data(String message, String tickerText, string contentTitle)
{
this.message = message;
this.tickerText = tickerText;
this.contentTitle = contentTitle;
}
};
}
a następnie można uzyskać ciąg JSON z wywołaniem
List<String> ids = new List<string>() { "id1", "id2" };
templateRequest request = new templeteRequest();
request.registration_ids = ids.ToArray();
request.data = new templateRequest.Data("Your message", "Your ticker", "Your content");
string json = new JavaScriptSerializer().Serialize(request);
Wynik będzie taki:
json = "{\"registration_ids\":[\"id1\",\"id2\"],\"data\":{\"message\":\"Your message\",\"tickerText\":\"Your ticket\",\"contentTitle\":\"Your content\"}}"
Mam nadzieję, że to pomoże!
Jeśli nie możesz lub nie chcesz używać dwóch wbudowanych serializatorów JSON ( JavaScriptSerializer i DataContractJsonSerializer ), możesz wypróbować bibliotekę JsonExSerializer - używam jej w wielu projektach i działa całkiem dobrze.
Jeśli próbujesz utworzyć usługę sieci Web do obsługi danych przez JSON na stronie internetowej, rozważ użycie zestawu narzędzi ASP.NET Ajax:
http://www.asp.net/learn/ajax/tutorial-05-cs.aspx
Automatycznie skonwertuje twoje obiekty obsługiwane przez usługę internetową na json i utworzy klasę proxy, której możesz użyć do połączenia się z nią.
DataContractJSONSerializer zrobi wszystko dla Ciebie z tym samym łatwe jak XMLSerializer. Używanie tego w aplikacji internetowej jest banalne. Jeśli używasz WCF, możesz określić jego użycie za pomocą atrybutu. Rodzina DataContractSerializer jest również bardzo szybka.
Przekonałem się, że w ogóle nie potrzebujesz serializatora. Jeśli zwrócisz obiekt jako listę. Pozwól mi skorzystać z przykładu.
W naszym asmx otrzymujemy dane przy użyciu zmiennej, którą przekazaliśmy
// return data
[WebMethod(CacheDuration = 180)]
public List<latlon> GetData(int id)
{
var data = from p in db.property
where p.id == id
select new latlon
{
lat = p.lat,
lon = p.lon
};
return data.ToList();
}
public class latlon
{
public string lat { get; set; }
public string lon { get; set; }
}
Następnie za pomocą jquery uzyskujemy dostęp do usługi, przekazując tę zmienną.
// get latlon
function getlatlon(propertyid) {
var mydata;
$.ajax({
url: "getData.asmx/GetLatLon",
type: "POST",
data: "{'id': '" + propertyid + "'}",
async: false,
contentType: "application/json;",
dataType: "json",
success: function (data, textStatus, jqXHR) { //
mydata = data;
},
error: function (xmlHttpRequest, textStatus, errorThrown) {
console.log(xmlHttpRequest.responseText);
console.log(textStatus);
console.log(errorThrown);
}
});
return mydata;
}
// call the function with your data
latlondata = getlatlon(id);
I otrzymujemy naszą odpowiedź.
{"d":[{"__type":"MapData+latlon","lat":"40.7031420","lon":"-80.6047970}]}
Zakoduj użycie
Prosty obiekt do JSON Array EncodeJsObjectArray ()
public class dummyObject
{
public string fake { get; set; }
public int id { get; set; }
public dummyObject()
{
fake = "dummy";
id = 5;
}
public override string ToString()
{
StringBuilder sb = new StringBuilder();
sb.Append('[');
sb.Append(id);
sb.Append(',');
sb.Append(JSONEncoders.EncodeJsString(fake));
sb.Append(']');
return sb.ToString();
}
}
dummyObject[] dummys = new dummyObject[2];
dummys[0] = new dummyObject();
dummys[1] = new dummyObject();
dummys[0].fake = "mike";
dummys[0].id = 29;
string result = JSONEncoders.EncodeJsObjectArray(dummys);
Wynik: [[29, „mike”], [5, „dummy”]]
Ładne użycie
Pretty print Metoda rozszerzenia ciągu JSON Array PrettyPrintJson ()
string input = "[14,4,[14,\"data\"],[[5,\"10.186.122.15\"],[6,\"10.186.122.16\"]]]";
string result = input.PrettyPrintJson();
Wyniki to:
[
14,
4,
[
14,
"data"
],
[
[
5,
"10.186.122.15"
],
[
6,
"10.186.122.16"
]
]
]