ASP.NET में एक सरल शब्दकोश <string> स्ट्रिंग> के लिए JSON का उपयोग कैसे किया जा सकता है?


682

मेरे पास JSON में एक साधारण कुंजी / मान सूची है जिसे पोस्ट के माध्यम से ASP.NET पर भेजा जा रहा है। उदाहरण:

{ "key1": "value1", "key2": "value2"}

मैं बहुत मजबूत TYPED NET OBJECTS में शामिल होने की कोशिश नहीं कर रहा हूँ

मुझे बस एक सादे पुराने शब्दकोश (स्ट्रिंग, स्ट्रिंग) , या कुछ समतुल्य (हैश टेबल, डिक्शनरी (स्ट्रिंग, ऑब्जेक्ट), पुराने स्कूल स्ट्रिंगर की जरूरत है - नरक, स्ट्रिंग्स का 2-डी सरणी मेरे लिए काम करेगा।

मैं ASP.NET 3.5 में उपलब्ध कुछ भी उपयोग कर सकता हूं, साथ ही लोकप्रिय Json.NET (जो मैं पहले से ही क्लाइंट के लिए उपयोग कर रहा हूं )।

जाहिरा तौर पर इन JSON पुस्तकालयों में से कोई भी इस माथे थप्पड़ स्पष्ट क्षमता बॉक्स से बाहर नहीं है - वे पूरी तरह से मजबूत अनुबंध के माध्यम से प्रतिबिंब आधारित deserialization पर ध्यान केंद्रित कर रहे हैं।

कोई विचार?

सीमाएं:

  1. मैं अपने खुद के JSON पार्सर को लागू नहीं करना चाहता
  2. अभी तक ASP.NET 4.0 का उपयोग नहीं किया जा सकता है
  3. JSON के लिए पुराने, पदावनत ASP.NET वर्ग से दूर रहना पसंद करेंगे

1
पुन: सीमा 3, JavaScriptSerizlizerASP.NET MVC में उपयोग किया जाता है और अब नहीं निकाला जाता है।
bdukes 14

17
यह अविश्वसनीय है कि एक मुश्किल स्ट्रिंग को जन्स स्ट्रिंग में बदलने के लिए एक सरल तरीका खोजना मुश्किल था, जिसे मैं आसानी से कई अलग-अलग स्टैकओवरफ़्लो के माध्यम से फ़्लिप किए बिना उपयोग कर सकता था। यह अन्य भाषाओं में इतना आसान है फिर भी जावा और सी # जीवन को कठिन बनाने के लिए अपने रास्ते से हट जाते हैं।
user299709

जवाबों:


893

Json.NET ऐसा करता है ...

string json = @"{""key1"":""value1"",""key2"":""value2""}";

var values = JsonConvert.DeserializeObject<Dictionary<string, string>>(json);

अधिक उदाहरण: Json.NET के साथ संग्रह को सीरियल करना


9
क्या यह भी काम करता है जब आप मान पूर्णांक होते हैं। क्या वे स्वचालित रूप से 'स्ट्रिंग्स' के लिए तैयार हैं?
हाईमास्टडन

58
@Highmastdon नहीं यह नहीं है। मैंने डिक्शनरी में dynamicJsonConvert.DeserializeObject<Dictionary<string, dynamic>>(json);
डिस्क्रिअलाइज़

1
इस पेज पर बहुत गन्दी कुंजी / मूल्य जोड़ी के साथ कई उत्तर देने की कोशिश की, और JSON.NET केवल एक ही है जो मैंने कोशिश की थी कि काम किया।
bnieland

15
काम नहीं करता है अगर आप json में प्रमुख मूल्य जोड़े की एक सरणी का उपयोग कर रहे हैं तो आपको [{key: "a", value: "1"}, {key: "b", value:"2"}]कुछ इस तरह करना होगा:var dict = JsonConvert.DeserializeObject<List<KeyValuePair<string, string>>>(json);
एड्रियन

8
मानों नेस्टेड ऑब्जेक्ट्स होने पर भी काम नहीं करता है, क्योंकि json.net जोबजेक्ट्स के रूप में बनाता है
Kugel

100

मैं डिस्कवर नेट एक एक में JSON स्ट्रिंग कास्ट करने के लिए रास्ते में बनाया गया है किया Dictionary<String, Object>के माध्यम से System.Web.Script.Serialization.JavaScriptSerializer3.5 में प्रकार System.Web.Extensionsविधानसभा। विधि का प्रयोग करें DeserializeObject(String)

स्टैटिक .net पेज मेथड / एप्लिकेशन टाइप / json के कंटेंट टाइप के jjax पोस्ट (jquery के माध्यम से) करते समय मैं इस पर अड़ गया। मैंने देखा कि विधि (जिसमें टाइप का एक ही पैरामीटर था Object) जादुई रूप से इस शब्दकोश को प्राप्त किया।


5
लेकिन javascriptserializer में बनाया गया json.net की तुलना में Buggier है, यह समाधान बेहतर है। उदाहरण के लिए javascriptseralizer रिक्त तारों के बजाय नल लौटाएगा, और अशक्त गुणों के लिए बिल्कुल भी काम नहीं करता है, और इसी तरह।
pilavdzice

1
@pilavdzice पार्स तारीखों की कोशिश करते समय आपके द्वारा किए गए मज़े का उल्लेख नहीं करना चाहिए क्योंकि यह एमएस के गैर-मानक तिथि प्रारूप को मानता है।
मूल

16
त्वरित कोड उदाहरण: var jsSerializer = new System.Web.Script.Serialization.JavaScriptSerializer();इसके बादDictionary<string, object> dict = (Dictionary<string, object>)jsSerializer.DeserializeObject(jsonString);
नैट कुक

6
एक साधारण मामले में नैट कुक के उदाहरण का लाभ बाहरी DLL की आवश्यकता से बचने के लिए है। मैं एक स्टैंडअलोन कंसोल से एक एपीआई का उपयोग कर रहा हूं जो केवल। नेट फ्रेमवर्क पर भरोसा कर सकता है।
Nick.T

क्या आप उस पर अधिक विस्तार से जा सकते हैं? मैं "खाली तारों के बदले वापसी नल" को पुन: उत्पन्न नहीं कर सकता, इसने मुझे एक रिक्त स्ट्रिंग मान दियाSomeData: ""
jrh

51

इंटरनेट पर खोज करने वालों और इस पोस्ट पर ठोकर खाने वालों के लिए, मैंने एक ब्लॉग पोस्ट लिखा कि कैसे JavaScriptSerializer क्लास का उपयोग किया जाए।

और पढ़ें ... http://procbits.com/2011/04/21/quick-json-serializationdeserialization-in-c/

यहाँ एक उदाहरण है:

var json = "{\"id\":\"13\", \"value\": true}";
var jss = new JavaScriptSerializer();
var table = jss.Deserialize<dynamic>(json);
Console.WriteLine(table["id"]);
Console.WriteLine(table["value"]);

हम्म, मैंने आपके समाधान की कोशिश की है ... मेरे पास इस तरह का {{आईडी ":" 13 "," मूल्य ": सच्चा} है और मेरे लिए केवल डिक्शनरी <गतिशील> समाधान कार्य
मार्को

ठीक है मैंने पाया कि यह समस्या कहां है ... आपको ठीक से डिस्क्राइब करने के लिए डिक्लेरेशन डिक्लेरेशन के बाद [] जोड़ना होगा ... मैं आपके ब्लॉग पोस्ट में कमेंट भी जोड़ रहा हूं ... चीयर्स;)
मार्को

मैंने आपके विशिष्ट डेटासेट को दर्शाने के लिए अपना उत्तर अपडेट कर दिया है। यह गतिशील के साथ ठीक काम करता है।
जेपी रिचर्डसन

मैंने अभी एक और JSON पार्सर लिखा है जो थोड़ा अधिक लचीला है और सिल्वरलाइट का समर्थन करता है: procbits.com/2011/08/11/…
JP Richardson

41

किसी भी बाहरी JSON कार्यान्वयन का उपयोग नहीं करने की कोशिश की, तो मैं इस तरह deserialised:

string json = "{\"id\":\"13\", \"value\": true}";

var serializer = new JavaScriptSerializer(); //using System.Web.Script.Serialization;

Dictionary<string, string> values = serializer.Deserialize<Dictionary<string, string>>(json);

6
संदर्भ जोड़ें। System.eb.Extensions का उपयोग करने के लिए System.Web.Script
Patrick Cullen

1
मुझे यह उत्तर सबसे अच्छा लगता है क्योंकि यह सरल है और .NET का उपयोग करता है System.Web.Script.Serialization। यह सिर्फ काम करता है। मैं भी "अमान्य" JSON का उपयोग करने में सक्षम था string json = "{'id':13, 'value': true}";
स्टाइल डेफ

जिज्ञासा से बाहर, क्या ऑर्डिनलइग्नोरकैसे शब्दकोश में deserialize करने के लिए एक ही रास्ता है?
बैटबार्ट

38

मुझे भी यही समस्या थी, इसलिए मैंने यह स्वयं लिखा। इस समाधान को अन्य उत्तरों से विभेदित किया जाता है क्योंकि यह कई स्तरों पर अलग हो सकता है।

बस JSON स्ट्रिंग को deserializeToDictionary फ़ंक्शन पर भेजें यह गैर-दृढ़ता से टाइप की गई Dictionary<string, object>वस्तु को वापस करेगा ।

पुराना कोड

private Dictionary<string, object> deserializeToDictionary(string jo)
{
    var values = JsonConvert.DeserializeObject<Dictionary<string, object>>(jo);
    var values2 = new Dictionary<string, object>();
    foreach (KeyValuePair<string, object> d in values)
    {
        // if (d.Value.GetType().FullName.Contains("Newtonsoft.Json.Linq.JObject"))
        if (d.Value is JObject)
        {
            values2.Add(d.Key, deserializeToDictionary(d.Value.ToString()));
        }
        else
        {
            values2.Add(d.Key, d.Value);
        }
    }
    return values2;
}

Ex: यह Dictionary<string, object>फेसबुक JSON प्रतिक्रिया की वस्तु लौटाएगा ।

परीक्षा

private void button1_Click(object sender, EventArgs e)
{
    string responsestring = "{\"id\":\"721055828\",\"name\":\"Dasun Sameera Weerasinghe\",\"first_name\":\"Dasun\",\"middle_name\":\"Sameera\",\"last_name\":\"Weerasinghe\",\"username\":\"dasun\",\"gender\":\"male\",\"locale\":\"en_US\",  hometown: {id: \"108388329191258\", name: \"Moratuwa, Sri Lanka\",}}";
    Dictionary<string, object> values = deserializeToDictionary(responsestring);
}

नोट: गृहनगर आगे एक Dictionary<string, object> वस्तु में deserilize ।

अपडेट करें

यदि JSON स्ट्रिंग पर कोई सरणी नहीं है, तो मेरा पुराना उत्तर बहुत अच्छा है। List<object>यदि कोई तत्व एक सरणी है, तो यह एक और deserialize है ।

बस एक JSON स्ट्रिंग को deserializeToDictionaryOrList फ़ंक्शन पर भेजें यह गैर-दृढ़ता से टाइप की गई Dictionary<string, object>वस्तु या वापस आ जाएगी List<object>

private static object deserializeToDictionaryOrList(string jo,bool isArray=false)
{
    if (!isArray)
    {
        isArray = jo.Substring(0, 1) == "[";
    }
    if (!isArray)
    {
        var values = JsonConvert.DeserializeObject<Dictionary<string, object>>(jo);
        var values2 = new Dictionary<string, object>();
        foreach (KeyValuePair<string, object> d in values)
        {
            if (d.Value is JObject)
            {
                values2.Add(d.Key, deserializeToDictionary(d.Value.ToString()));
            }
            else if (d.Value is JArray)
            {
                values2.Add(d.Key, deserializeToDictionary(d.Value.ToString(), true));
            }
            else
            {
                values2.Add(d.Key, d.Value);
            }
        }
        return values2;
    }else
    {
        var values = JsonConvert.DeserializeObject<List<object>>(jo);
        var values2 = new List<object>();
        foreach (var d in values)
        {
            if (d is JObject)
            {
                values2.Add(deserializeToDictionary(d.ToString()));
            }
            else if (d is JArray)
            {
                values2.Add(deserializeToDictionary(d.ToString(), true));
            }
            else
            {
                values2.Add(d);
            }
        }
        return values2;
    }
}

@ जोर्डन ने इंगित करने के लिए धन्यवाद, मैंने इस कोड में कुछ संशोधन किया है, लेकिन मेरे पास अब नहीं है। यह कोड JArray ऑब्जेक्ट्स को हैंडल नहीं करता है, एक बार मेरे पास यह कोड अपडेट हो जाएगा।
दासुन

1
एक समस्या नहीं है। मैं केवल इसका उल्लेख करता हूं क्योंकि isऔर asऑपरेटरों के बारे में जानने से मुझे बहुत मदद मिली और मैंने अपने कोड को सरल बनाया।
जॉर्डन

यह काम करता है, लेकिन कुशल नहीं है, क्योंकि यह ToString और फिर Deserialize कहता है। नीचे फल्को के उत्तर को देखें। यह स्रोत स्ट्रिंग को केवल एक बार डिसेर्बलाइज करता है।
सर्गेई ज़िनोवायेव

1
फल्को का उत्तर केवल तभी काम करता है जब आप पहले से डेटा संरचना को जानते हैं। यह समाधान किसी भी JSON स्ट्रिंग के लिए उपयोग कर सकता है।
दासुन

16

यदि आप हल्के, नो-एडेड-रेफरेंस तरह के दृष्टिकोण के बाद हैं, तो शायद मैंने जो कोड लिखा है, वह काम करेगा (हालांकि मैं 100% मजबूती की गारंटी नहीं दे सकता)।

using System;
using System.Collections.Generic;
using System.Text;
using System.Text.RegularExpressions;

public Dictionary<string, object> ParseJSON(string json)
{
    int end;
    return ParseJSON(json, 0, out end);
}
private Dictionary<string, object> ParseJSON(string json, int start, out int end)
{
    Dictionary<string, object> dict = new Dictionary<string, object>();
    bool escbegin = false;
    bool escend = false;
    bool inquotes = false;
    string key = null;
    int cend;
    StringBuilder sb = new StringBuilder();
    Dictionary<string, object> child = null;
    List<object> arraylist = null;
    Regex regex = new Regex(@"\\u([0-9a-z]{4})", RegexOptions.IgnoreCase);
    int autoKey = 0;
    for (int i = start; i < json.Length; i++)
    {
        char c = json[i];
        if (c == '\\') escbegin = !escbegin;
        if (!escbegin)
        {
            if (c == '"')
            {
                inquotes = !inquotes;
                if (!inquotes && arraylist != null)
                {
                    arraylist.Add(DecodeString(regex, sb.ToString()));
                    sb.Length = 0;
                }
                continue;
            }
            if (!inquotes)
            {
                switch (c)
                {
                    case '{':
                        if (i != start)
                        {
                            child = ParseJSON(json, i, out cend);
                            if (arraylist != null) arraylist.Add(child);
                            else
                            {
                                dict.Add(key, child);
                                key = null;
                            }
                            i = cend;
                        }
                        continue;
                    case '}':
                        end = i;
                        if (key != null)
                        {
                            if (arraylist != null) dict.Add(key, arraylist);
                            else dict.Add(key, DecodeString(regex, sb.ToString()));
                        }
                        return dict;
                    case '[':
                        arraylist = new List<object>();
                        continue;
                    case ']':
                        if (key == null)
                        {
                            key = "array" + autoKey.ToString();
                            autoKey++;
                        }
                        if (arraylist != null && sb.Length > 0)
                        {
                            arraylist.Add(sb.ToString());
                            sb.Length = 0;
                        }
                        dict.Add(key, arraylist);
                        arraylist = null;
                        key = null;
                        continue;
                    case ',':
                        if (arraylist == null && key != null)
                        {
                            dict.Add(key, DecodeString(regex, sb.ToString()));
                            key = null;
                            sb.Length = 0;
                        }
                        if (arraylist != null && sb.Length > 0)
                        {
                            arraylist.Add(sb.ToString());
                            sb.Length = 0;
                        }
                       continue;
                    case ':':
                        key = DecodeString(regex, sb.ToString());
                        sb.Length = 0;
                        continue;
                }
            }
        }
        sb.Append(c);
        if (escend) escbegin = false;
        if (escbegin) escend = true;
        else escend = false;
    }
    end = json.Length - 1;
    return dict; //theoretically shouldn't ever get here
}
private string DecodeString(Regex regex, string str)
{
    return Regex.Unescape(regex.Replace(str, match => char.ConvertFromUtf32(Int32.Parse(match.Groups[1].Value, System.Globalization.NumberStyles.HexNumber))));
}

[मुझे पता है कि यह ओपी लिमिटेशन # 1 का उल्लंघन करता है, लेकिन तकनीकी रूप से, आपने इसे नहीं लिखा, मैंने किया]


3
यह केवल जवाब है कि सिल्वरलाइट के लिए काम करना और बिना निर्भरता के! सिल्वरलाइट में JavascriptSerializer या Serializable नहीं है। और कोई निर्भरता का मतलब कोई Json.NET, RestSharp या MiniJSON नहीं है। केवल @DanCsharpster ने एक और संभावित समाधान की कोशिश की, लेकिन दुर्भाग्य से यह मेरे लिए काम नहीं कर रहा था जैसे यह करता है।
Cœur

1
JSON.NET जैसी सरल चीज़ के संदर्भ को जोड़ने में क्या गलत है? क्या उस हल्के होने की ज़रूरत है कि आप कुछ भी संदर्भ नहीं दे सकते? मैं यह नहीं कह रहा हूं कि आपका कोड काम नहीं करेगा, लेकिन कभी भी आप अपना रोल करते हैं, तो जाहिर है कि आपके कोड का जोखिम उतना मजबूत नहीं होता है, जो एज केस जैसी चीजों के लिए, या JSON.NET जैसी टेस्टेड लाइब्रेरी के रूप में तेजी से होता है।
दान Csharpster

1
जब आपके पास कोई अच्छा विकल्प हो तो अपना खुद का रोल करना एक बुरा विचार है। मुझे पता है कि कोई स्थिति नहीं है कि हल्का हो। और मेरे पास कम इष्टतम कोड होगा जो पढ़ना और बदलना आसान है।
जॉर्डन

3
मैंने मूल रूप से उस कोड ऑफ कोड को लिखा था क्योंकि मेरे पास कोई विकल्प नहीं था। कार्यालय उत्पादों के लिए सिल्वरलाइट, या विभिन्न प्रकार के प्रदाताओं जैसी चीजों पर विचार करें, जहां परियोजना के लिए बाहरी संदर्भ जोड़ना या तो अत्यंत समस्याग्रस्त या असंभव है।
dexy

मुझे इसके कुछ साल बाद पता है, लेकिन यह अभी भी एक बहुत ही वैध प्रश्न है। किसी को भी आश्चर्य होगा कि हम इतना हल्का क्यों जाना चाहते हैं, ठीक है, यदि आप SQL CLR C # के साथ काम कर रहे हैं, तो केवल इतनी "सुरक्षित" लाइब्रेरियाँ हैं जिनका आप उपयोग कर सकते हैं और System.RunTime.Serializationउनमें से एक भी नहीं है, दुर्भाग्य से JSON.NET इस पर निर्भर करता है इसे और इस प्रकार इसका उपयोग नहीं किया जा सकता है। आपके शानदार काम के लिए धन्यवाद, मैंने इस पर सुधार करने की हिम्मत की, ताकि मैं सरणियों की सारणी को निष्क्रिय कर सकूं, मेरे उत्तर में अद्यतन कोड यहां देखें
अल्बर्टो रेची

15

मुझे बस एक नेस्टेड शब्दकोश को पार्स करने की आवश्यकता थी , जैसे

{
    "x": {
        "a": 1,
        "b": 2,
        "c": 3
    }
}

कहाँ JsonConvert.DeserializeObjectमदद नहीं करता है मुझे निम्नलिखित दृष्टिकोण मिला:

var dict = JObject.Parse(json).SelectToken("x").ToObject<Dictionary<string, int>>();

SelectTokenआप इच्छित क्षेत्र के लिए नीचे खुदाई करने देता है। आप "x.y.z"JSON ऑब्जेक्ट में और नीचे जाने के लिए एक पथ निर्दिष्ट कर सकते हैं ।


JObject.Parse (JSON) .ToObject <शब्दकोश <Guid, सूची <int >>> () मेरी परिदृश्य धन्यवाद में मेरे लिए काम किया
geedubb

11

System.Text.Json

अब इसका उपयोग किया जा सकता है System.Text.Jsonजो बिल्ट-इन है .net core 3.0। अब थर्ड पार्टी लाइब्रेरियों का उपयोग किए बिना JSON को डिसेर्बलाइज करना संभव है ।

var json = @"{""key1"":""value1"",""key2"":""value2""}";
var values = JsonSerializer.Deserialize<Dictionary<string, string>>(json);

इसके अलावा nu-get package System.Text.Json में उपलब्ध है । अगर .Net Standard या .Net फ्रेमवर्क का उपयोग किया जाता है।


1
हाँ! System.Text.Jsonइन दिनों जाने का रास्ता है।
mfluehr

2
हाँ, यह आशाजनक लगता है! हालाँकि, ध्यान दें कि .NET कोर 3.1 का डिफ़ॉल्ट संस्करण System.Text.Json गैर-स्ट्रिंग कुंजियों के साथ डिस्क्रिअलाइज़िंग डिक्शनरी का समर्थन नहीं करता है। जबकि मेरा ओपी स्ट्रिंग्स के बारे में था, अब प्रैक्टिस में, मेरे पास बहुत सी गाइड कीज़ हैं, इसलिए स्विच बनाने की कोशिश करते समय यह "बिट" होता है। इसमें कुछ विशेषताओं (आवश्यक, आदि) के समकक्ष भी नहीं हैं।
ऋचाधालय

6

मार्क रेंडले ने इसे एक टिप्पणी के रूप में पोस्ट किया था, मैं इसे एक उत्तर के रूप में पोस्ट करना चाहता था क्योंकि यह एकमात्र समाधान है जिसने अब तक सफलता और रिटर्न-कोड के परिणाम को वापस करने के लिए Google reCaptcha प्रतिक्रिया से परिणाम दिया है।

string jsonReponseString= wClient.DownloadString(requestUrl);    
IDictionary<string, object> dict = new JavaScriptSerializer().DeserializeObject(jsonReponseString) as IDictionary<string, object>;

धन्यवाद फिर से, मार्क!


1
JavaScriptSerializer को लगभग पदावनत कर दिया गया है। प्रलेखन का कहना है कि हमें JSON.NET ( docs.microsoft.com/en-us/dotnet/api/… ) का उपयोग करना चाहिए
मारियो लोपेज़

उन विरासत वेबफोर्म ऐप्स के लिए भी अच्छा है जहाँ आप अतिरिक्त निर्भरता को शामिल नहीं करना चाहते हैं।
एंड्रयू ग्रोथे

5

संपादित करें: यह काम करता है, लेकिन Json.NET का उपयोग करके स्वीकृत उत्तर अधिक सीधा है। यदि किसी को BCL- केवल कोड की आवश्यकता है, तो इसे छोड़कर।

यह .NET फ्रेमवर्क आउट ऑफ द बॉक्स द्वारा समर्थित नहीं है। एक चमकती हुई दृष्टि - हर किसी को नामित गुणों वाली वस्तुओं में शामिल नहीं होना चाहिए। इसलिए मैंने अपना रोल अप किया:

<Serializable()> Public Class StringStringDictionary
    Implements ISerializable
    Public dict As System.Collections.Generic.Dictionary(Of String, String)
    Public Sub New()
        dict = New System.Collections.Generic.Dictionary(Of String, String)
    End Sub
    Protected Sub New(info As SerializationInfo, _
          context As StreamingContext)
        dict = New System.Collections.Generic.Dictionary(Of String, String)
        For Each entry As SerializationEntry In info
            dict.Add(entry.Name, DirectCast(entry.Value, String))
        Next
    End Sub
    Public Sub GetObjectData(info As SerializationInfo, context As StreamingContext) Implements ISerializable.GetObjectData
        For Each key As String in dict.Keys
            info.AddValue(key, dict.Item(key))
        Next
    End Sub
End Class

इसके साथ कॉल किया गया:

string MyJsonString = "{ \"key1\": \"value1\", \"key2\": \"value2\"}";
System.Runtime.Serialization.Json.DataContractJsonSerializer dcjs = new
  System.Runtime.Serialization.Json.DataContractJsonSerializer(
    typeof(StringStringDictionary));
System.IO.MemoryStream ms = new
  System.IO.MemoryStream(Encoding.UTF8.GetBytes(MyJsonString));
StringStringDictionary myfields = (StringStringDictionary)dcjs.ReadObject(ms);
Response.Write("Value of key2: " + myfields.dict["key2"]);

C # और VB.NET के मिश्रण के लिए क्षमा करें ...


2
[TestMethod] सार्वजनिक शून्य TestSimpleObject () {const string json = @ "" "" Name "": "" Bob "", "" Age "": 42} "; var dict = new JavaScript Assert.IsNotNull (dict); Assert.IsTrue (dict.ContainsKey ( "नाम")); Assert.AreEqual ("बॉब", तानाशाह ["नाम"]); Assert.IsTrue (dict.ContainsKey ( "आयु")); Assert.AreEqual (42, तानाशाह ["आयु"]); }
मार्क रेंडले

1
यह शानदार है। WCF सेवा कार्यान्वयन में मदद करता है जो ब्राउज़र आधारित क्लाइंट के साथ JSON का उपयोग करके इंटरफ़ेस करता है।
एंटोन

@ मर्क रेंडले: आपका कार्यान्वयन बहुत सरल है, और केवल एक ही है जिसने मेरे लिए अब तक सफलता और त्रुटि-कोड जोंस परिणाम प्राप्त करने में काम किया है। मैंने कई समाधानों की कोशिश की है, इसलिए टिप्पणी के रूप में पोस्ट करने के लिए धन्यवाद। इसका उत्तर होना चाहिए।
ब्रायन

5

मैंने jSnake04 और दासुन द्वारा प्रस्तुत कोड पर जोड़ा है। मैंने JArrayउदाहरणों से वस्तुओं की सूची बनाने के लिए कोड जोड़ा है । इसमें दो तरफ़ा पुनरावृत्ति है लेकिन जब यह एक निश्चित, परिमित वृक्ष मॉडल पर काम कर रहा है, तब तक स्टैक ओवरफ्लो का कोई खतरा नहीं है जब तक कि डेटा बड़े पैमाने पर न हो।

/// <summary>
/// Deserialize the given JSON string data (<paramref name="data"/>) into a
///   dictionary.
/// </summary>
/// <param name="data">JSON string.</param>
/// <returns>Deserialized dictionary.</returns>
private IDictionary<string, object> DeserializeData(string data)
{
    var values = JsonConvert.DeserializeObject<Dictionary<string, object>>(data);

    return DeserializeData(values);
}

/// <summary>
/// Deserialize the given JSON object (<paramref name="data"/>) into a dictionary.
/// </summary>
/// <param name="data">JSON object.</param>
/// <returns>Deserialized dictionary.</returns>
private IDictionary<string, object> DeserializeData(JObject data)
{
    var dict = data.ToObject<Dictionary<String, Object>>();

    return DeserializeData(dict);
}

/// <summary>
/// Deserialize any elements of the given data dictionary (<paramref name="data"/>) 
///   that are JSON object or JSON arrays into dictionaries or lists respectively.
/// </summary>
/// <param name="data">Data dictionary.</param>
/// <returns>Deserialized dictionary.</returns>
private IDictionary<string, object> DeserializeData(IDictionary<string, object> data)
{
    foreach (var key in data.Keys.ToArray()) 
    {
        var value = data[key];

        if (value is JObject)
            data[key] = DeserializeData(value as JObject);

        if (value is JArray)
            data[key] = DeserializeData(value as JArray);
    }

    return data;
}

/// <summary>
/// Deserialize the given JSON array (<paramref name="data"/>) into a list.
/// </summary>
/// <param name="data">Data dictionary.</param>
/// <returns>Deserialized list.</returns>
private IList<Object> DeserializeData(JArray data)
{
    var list = data.ToObject<List<Object>>();

    for (int i = 0; i < list.Count; i++)
    {
        var value = list[i];

        if (value is JObject)
            list[i] = DeserializeData(value as JObject);

        if (value is JArray)
            list[i] = DeserializeData(value as JArray);
    }

    return list;
}

4

मैंने JSON में शून्य मानों के लिए अन्य उत्तर के लिए एक चेक जोड़ा

मुझे भी यही समस्या थी इसलिए मैंने इसे लिखा। इस समाधान को अन्य उत्तरों से विभेदित किया जाता है क्योंकि यह कई स्तरों पर अलग हो सकता है।

बस deserializeToरोधी फ़ंक्शन में json स्ट्रिंग भेजें यह गैर-दृढ़ता से टाइप की गई Dictionary<string, object>वस्तु को लौटाएगा ।

private Dictionary<string, object> deserializeToDictionary(string jo)
{
    var values = JsonConvert.DeserializeObject<Dictionary<string, object>>(jo);
    var values2 = new Dictionary<string, object>();
    foreach (KeyValuePair<string, object> d in values)
    {
        if (d.Value != null && d.Value.GetType().FullName.Contains("Newtonsoft.Json.Linq.JObject"))
        {
            values2.Add(d.Key, deserializeToDictionary(d.Value.ToString()));
        }
        else
        {
            values2.Add(d.Key, d.Value);
        }
    }
    return values2;
}

Ex: यह Dictionary<string, object>फेसबुक JSON प्रतिक्रिया की वस्तु लौटाएगा ।

private void button1_Click(object sender, EventArgs e)
{
    string responsestring = "{\"id\":\"721055828\",\"name\":\"Dasun Sameera
        Weerasinghe\",\"first_name\":\"Dasun\",\"middle_name\":\"Sameera\",\"last_name\":\"Weerasinghe\",\"username\":\"dasun\",\"gender\":\"male\",\"locale\":\"en_US\",
        hometown: {id: \"108388329191258\", name: \"Moratuwa, Sri Lanka\",}}";
    Dictionary<string, object> values = deserializeToDictionary(responsestring);
}

नोट: गृहनगर एक Dictionary<string, object>वस्तु में आगे deserialize ।


1
+1 जैसा कि मैंने ऊपर दासुन के साथ कहा। आप बस जाँच कर सकते हैं कि क्या d.Value is JObject। आपको चेक प्रकारों के माध्यम से जाने की ज़रूरत नहीं है। और isऑपरेटर के साथ आपको शून्य की जांच करने की आवश्यकता नहीं है। यदि वस्तु अशक्त है तो यह गलत है।
जॉर्डन

3

ऐसा लगता है कि ये सभी उत्तर यहां दिए गए हैं, आप मान सकते हैं कि आप किसी बड़ी वस्तु से उस छोटे तार को प्राप्त कर सकते हैं ... मैपिंग के अंदर कहीं इस तरह के शब्दकोश के साथ एक बड़ी वस्तु को देखने की इच्छा रखने वाले लोगों के लिए, और जो System.Runtime.Serialization.JsonDataContract प्रणाली का उपयोग कर रहे हैं , यहां है एक तरकीब:

Gis.stackexchange.com पर एक उत्तर में यह दिलचस्प लिंक था । मुझे इसे आर्काइव.ऑर्ग के साथ पुनर्प्राप्त करना था, लेकिन यह एक बहुत ही सटीक समाधान प्रदान करता है: एक कस्टम IDataContractSurrogateवर्ग जिसमें आप बिल्कुल अपने प्रकारों को लागू करते हैं। मैं इसका विस्तार आसानी से कर पा रहा था।

मैंने इसमें परिवर्तनों का एक गुच्छा बनाया, हालाँकि। चूंकि मूल स्रोत अब उपलब्ध नहीं है, इसलिए मैं पूरी कक्षा यहां पोस्ट करूंगा:

using System;
using System.CodeDom;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Json;
using System.Text;

namespace JsonTools
{
    /// <summary>
    /// Allows using Dictionary&lt;String,String&gt; and Dictionary&lt;String,Boolean&gt; types, and any others you'd like to add.
    /// Source: https://web.archive.org/web/20100317222656/my6solutions.com/post/2009/06/30/DataContractSerializer-DataContractJsonSerializer-JavaScriptSerializer-XmlSerializer-for-serialization.aspx
    /// </summary>
    public class JsonSurrogate : IDataContractSurrogate
    {
        /// <summary>
        /// Deserialize an object with added support for the types defined in this class.
        /// </summary>
        /// <typeparam name="T">Contract class</typeparam>
        /// <param name="json">JSON String</param>
        /// <param name="encoding">Text encoding</param>
        /// <returns>The deserialized object of type T</returns>
        public static T Deserialize<T>(String json, Encoding encoding)
        {
            if (encoding == null)
                encoding = new UTF8Encoding(false);
            DataContractJsonSerializer deserializer = new DataContractJsonSerializer(
                typeof(T), new Type[0], int.MaxValue, true, new JsonSurrogate(), false);
            using (MemoryStream stream = new MemoryStream(encoding.GetBytes(json)))
            {
                T result = (T)deserializer.ReadObject(stream);
                return result;
            }
        }

        // make sure all values in this are classes implementing JsonSurrogateObject.
        private static Dictionary<Type, Type> KnownTypes = 
            new Dictionary<Type, Type>()
            {
                {typeof(Dictionary<String, String>), typeof(SSDictionary)},
                {typeof(Dictionary<String, Boolean>), typeof(SBDictionary)}
            };

        #region Implemented surrogate dictionary classes

        [Serializable]
        public class SSDictionary : SurrogateDictionary<String>
        {
            public SSDictionary() : base() {}
            protected SSDictionary (SerializationInfo info, StreamingContext context) : base(info, context) {}
        }
        [Serializable]
        public class SBDictionary : SurrogateDictionary<Boolean>
        {
            public SBDictionary() : base() {}
            protected SBDictionary (SerializationInfo info, StreamingContext context) : base(info, context) {}
        }

        #endregion

        /// <summary>Small interface to easily extract the final value from the object.</summary>
        public interface JsonSurrogateObject
        {
            Object DeserializedObject { get; }
        }

        /// <summary>
        /// Class for deserializing any simple dictionary types with a string as key.
        /// </summary>
        /// <typeparam name="T">Any simple type that will be deserialized correctly.</typeparam>
            [Serializable]
        public abstract class SurrogateDictionary<T> : ISerializable, JsonSurrogateObject
        {
            public Object DeserializedObject { get { return dict; } }
            private Dictionary<String, T> dict;

            public SurrogateDictionary()
            {
                dict = new Dictionary<String, T>();
            }

            // deserialize
            protected SurrogateDictionary(SerializationInfo info, StreamingContext context)
            {
                dict = new Dictionary<String, T>();
                foreach (SerializationEntry entry in info)
                {
                    // This cast will only work for base types, of course.
                    dict.Add(entry.Name, (T)entry.Value);
                }
            }
            // serialize
            public void GetObjectData(SerializationInfo info, StreamingContext context)
            {
                foreach (String key in dict.Keys)
                {
                    info.AddValue(key, dict[key]);
                }
            }

        }

        /// <summary>
            /// Uses the KnownTypes dictionary to get the surrogate classes.
        /// </summary>
        /// <param name="type"></param>
        /// <returns></returns>
        public Type GetDataContractType(Type type)
        {
            Type returnType;
            if (KnownTypes.TryGetValue(type, out returnType))
            {
                return returnType;
            }
            return type;
        }

        public object GetObjectToSerialize(object obj, Type targetType)
        {
            throw new NotImplementedException();
        }

        /// <summary>
        ///     Gets the object out of the surrogate datacontract object. This function is the reason all surrogate objects need to implement the JsonSurrogateObject class.
        /// </summary>
        /// <param name="obj">Result of the deserialization</param>
        /// <param name="targetType">Expected target type of the deserialization</param>
        /// <returns></returns>
        public object GetDeserializedObject(object obj, Type targetType)
        {
            if (obj is JsonSurrogateObject)
            {
                return ((JsonSurrogateObject)obj).DeserializedObject;
            }
            return obj;
        }

        public Type GetReferencedTypeOnImport(string typeName, string typeNamespace, object customData)
        {
            return null;
        }

        #region not implemented

        public object GetCustomDataToExport(MemberInfo memberInfo, Type dataContractType)
        {
            throw new NotImplementedException();
        }

        public object GetCustomDataToExport(Type clrType, Type dataContractType)
        {
            throw new NotImplementedException();
        }

        public void GetKnownCustomDataTypes(Collection<Type> customDataTypes)
        {
            throw new NotImplementedException();
        }

        public CodeTypeDeclaration ProcessImportedType(CodeTypeDeclaration typeDeclaration, CodeCompileUnit compileUnit)
        {
            throw new NotImplementedException();
        }

        #endregion
    }
}

नए समर्थित प्रकारों को कक्षा में जोड़ने के लिए, आपको बस अपनी कक्षा को जोड़ने की जरूरत है, इसे सही कंस्ट्रक्टर और फ़ंक्शन दें ( SurrogateDictionaryउदाहरण के लिए देखें), सुनिश्चित करें कि यह विरासत में मिला है JsonSurrogateObject, और KnownTypesशब्दकोश में इसके प्रकार की मैपिंग जोड़ें । शामिल सरोगेटेबेर किसी भी Dictionary<String,T>प्रकार के लिए आधार के रूप में कार्य कर सकता है जहां टी किसी भी प्रकार का है जो सही ढंग से डिसरिज़लाइज़ करता है।

इसे कॉल करना वास्तव में सरल है:

MyObjtype newObj = JsonSurrogate.Deserialize<MyObjtype>(jsonStr, encoding);

ध्यान दें कि किसी कारण से इस चीज को महत्वपूर्ण तारों का उपयोग करने में परेशानी होती है जिसमें रिक्त स्थान होते हैं; वे बस अंतिम सूची में मौजूद नहीं थे। हो सकता है कि यह सिर्फ जोंस के चश्मे के खिलाफ हो और मैं जिस एपीआई को फोन कर रहा था, उसे खराब तरीके से लागू किया गया था, आपको बुरा लगा; मुझे नही पता। वैसे भी, मैंने इसे regex से बदलकर कच्चे जोंस डेटा में अंडरस्कोर के साथ बदल दिया और डिसेरिएलाइज़ेशन के बाद शब्दकोश को ठीक किया।


वैसे, कुछ अजीबोगरीब कारणों से मोनो को इस सामान को चलाने में परेशानी होती है ...
Nyerguds

साझा करने के लिए धन्यवाद, दुर्भाग्य से यह समाधान गैर-आदिम प्रकारों का समर्थन नहीं करता है, और कच्चे मूल्य प्राप्त करने का कोई तरीका नहीं है, इसलिए आप इसे स्वयं बना सकते हैं। यदि मैं अपने कस्टम प्रकार को नाउनटाइप्स में पंजीकृत करता हूं और इसका उपयोग शब्दकोश में करता हूं, तो यह पहले शब्दकोश कहता है, मैं अपेक्षा करूंगा कि यह सबसे दूरस्थ प्रकारों से नीचे तक और अधिक जटिल लोगों को पार्स करना शुरू कर दे।
इवान लियोनेंको

खैर, सवाल केवल के बारे में पूछा Dictionary<String,String>। मैंने ईमानदारी से इस प्रणाली के साथ जटिल प्रकारों को हटाने की कोशिश नहीं की।
Nyerguds

3

ऊपर की टिप्पणियों के आधार पर प्रयास करेंJsonConvert.DeserializeObject<Dictionary<string,dynamic>>(json)

var json = @"{""key1"":1,""key2"":""value2"", ""object1"":{""property1"":""value1"",""property2"":[2,3,4,5,6,7]}}";
var parsedObject = JsonConvert.DeserializeObject<Dictionary<string,dynamic>>(json);

जटिल वस्तुओं और सूचियों के लिए भी काम करने लगता है।


1

मैंने अभी इसे RestSharp में लागू किया है । यह पोस्ट मेरे लिए मददगार थी।

लिंक में कोड के अलावा, यहां मेरा कोड है। Dictionaryजब मुझे कुछ ऐसा करना होता है तो मुझे अब परिणाम मिलते हैं:

var jsonClient = new RestClient(url.Host);
jsonClient.AddHandler("application/json", new DynamicJsonDeserializer());
var jsonRequest = new RestRequest(url.Query, Method.GET);
Dictionary<string, dynamic> response = jsonClient.Execute<JObject>(jsonRequest).Data.ToObject<Dictionary<string, dynamic>>();

जिस तरह की JSON की आप अपेक्षा कर रहे हैं, उसके प्रति सावधान रहें - मेरे मामले में, मैं कई गुणों के साथ एक ही वस्तु प्राप्त कर रहा था। संलग्न लिंक में, लेखक एक सूची प्राप्त कर रहा था।


1

जोबजेक्ट या एक्सपेंडऑबजेक्ट के बीच के बिना, मेरा दृष्टिकोण सीधे IDEDIA के लिए डिजर्व करता है। कोड कनवर्टर का उपयोग करता है, जो मूल रूप से JSON.NET सोर्सकोड में पाए गए ExpandoObjectConverter वर्ग से कॉपी किया गया है, लेकिन ExpandoObject के बजाय IDEDIA का उपयोग कर रहा है।

उपयोग:

var settings = new JsonSerializerSettings()
{
    Converters = { new DictionaryConverter() },
};
var result = JsonConvert.DeserializeObject<IDictionary<string, object>>(json, settings);

कोड:

// based on ExpandoObjectConverter, but using arrays instead of IList, to behave similar to System.Web.Script.Serialization.JavaScriptSerializer
public class DictionaryConverter : JsonConverter
{
    public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
    {
    }

    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
    {
        return ReadValue(reader);
    }

    public override bool CanConvert(Type objectType)
    {
        return (objectType == typeof(IDictionary<string, object>));
    }

    public override bool CanWrite
    {
        get { return false; }
    }

    private object ReadValue(JsonReader reader)
    {
        while (reader.TokenType == JsonToken.Comment)
        {
            if (!reader.Read())
                throw JsonSerializationExceptionCreate(reader, "Unexpected end when reading IDictionary<string, object>.");
        }

        switch (reader.TokenType)
        {
            case JsonToken.StartObject:
                return ReadObject(reader);
            case JsonToken.StartArray:
                return ReadList(reader);
            default:
                if (IsPrimitiveToken(reader.TokenType))
                    return reader.Value;

                throw JsonSerializationExceptionCreate(reader, string.Format(CultureInfo.InvariantCulture, "Unexpected token when converting IDictionary<string, object>: {0}", reader.TokenType));
        }
    }

    private object ReadList(JsonReader reader)
    {
        List<object> list = new List<object>();

        while (reader.Read())
        {
            switch (reader.TokenType)
            {
                case JsonToken.Comment:
                    break;
                default:
                    object v = ReadValue(reader);

                    list.Add(v);
                    break;
                case JsonToken.EndArray:
                    return list;
            }
        }

        throw JsonSerializationExceptionCreate(reader, "Unexpected end when reading IDictionary<string, object>.");
    }

    private object ReadObject(JsonReader reader)
    {
        IDictionary<string, object> dictionary = new Dictionary<string, object>();
        while (reader.Read())
        {
            switch (reader.TokenType)
            {
                case JsonToken.PropertyName:
                    string propertyName = reader.Value.ToString();

                    if (!reader.Read())
                        throw JsonSerializationExceptionCreate(reader, "Unexpected end when reading IDictionary<string, object>.");

                    object v = ReadValue(reader);

                    dictionary[propertyName] = v;
                    break;
                case JsonToken.Comment:
                    break;
                case JsonToken.EndObject:
                    return dictionary;
            }
        }

        throw JsonSerializationExceptionCreate(reader, "Unexpected end when reading IDictionary<string, object>.");
    }

    //based on internal Newtonsoft.Json.JsonReader.IsPrimitiveToken
    internal static bool IsPrimitiveToken(JsonToken token)
    {
        switch (token)
        {
            case JsonToken.Integer:
            case JsonToken.Float:
            case JsonToken.String:
            case JsonToken.Boolean:
            case JsonToken.Undefined:
            case JsonToken.Null:
            case JsonToken.Date:
            case JsonToken.Bytes:
                return true;
            default:
                return false;
        }
    }

    // based on internal Newtonsoft.Json.JsonSerializationException.Create
    private static JsonSerializationException JsonSerializationExceptionCreate(JsonReader reader, string message, Exception ex = null)
    {
        return JsonSerializationExceptionCreate(reader as IJsonLineInfo, reader.Path, message, ex);
    }

    // based on internal Newtonsoft.Json.JsonSerializationException.Create
    private static JsonSerializationException JsonSerializationExceptionCreate(IJsonLineInfo lineInfo, string path, string message, Exception ex)
    {
        message = JsonPositionFormatMessage(lineInfo, path, message);

        return new JsonSerializationException(message, ex);
    }

    // based on internal Newtonsoft.Json.JsonPosition.FormatMessage
    internal static string JsonPositionFormatMessage(IJsonLineInfo lineInfo, string path, string message)
    {
        if (!message.EndsWith(Environment.NewLine))
        {
            message = message.Trim();

            if (!message.EndsWith(".", StringComparison.Ordinal))
                message += ".";

            message += " ";
        }

        message += string.Format(CultureInfo.InvariantCulture, "Path '{0}'", path);

        if (lineInfo != null && lineInfo.HasLineInfo())
            message += string.Format(CultureInfo.InvariantCulture, ", line {0}, position {1}", lineInfo.LineNumber, lineInfo.LinePosition);

        message += ".";

        return message;
    }
}

1

आप टिनी-JSON का उपयोग कर सकते हैं

string json = "{\"key1\":\"value1\", \"key2\":\"value2\"}";
IDictionary<string, string> dict = Tiny.Json.Decode<Dictionary<string, string>>(json);

1

खेल के लिए थोड़ा देर हो गई, लेकिन उपरोक्त समाधानों में से एक ने मुझे शुद्ध और सरल .NET की दिशा में इंगित किया, कोई json.net समाधान नहीं। तो यह यहाँ है, बहुत सरल होने के नाते समाप्त हो गया। मानक .NET Json क्रमांकन के साथ यह कैसे किया जाता है, इसके एक पूर्ण चल रहे उदाहरण के नीचे, उदाहरण में रूट ऑब्जेक्ट और चाइल्ड ऑब्जेक्ट्स दोनों में डिक्शनरी है।

गोल्डन बुलेट इस बिल्ली है, धारावाहिक के लिए दूसरे पैरामीटर के रूप में सेटिंग्स पार्स:

DataContractJsonSerializerSettings settings =
                       new DataContractJsonSerializerSettings();
                    settings.UseSimpleDictionaryFormat = true;

नीचे पूर्ण कोड:

using System;
using System.Collections.Generic;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Json;

    namespace Kipon.dk
    {
        public class JsonTest
        {
            public const string EXAMPLE = @"{
                ""id"": ""some id"",
                ""children"": {
                ""f1"": {
                    ""name"": ""name 1"",
                    ""subs"": {
                    ""1"": { ""name"": ""first sub"" },
                    ""2"": { ""name"": ""second sub"" }
                    }
                },
                ""f2"": {
                    ""name"": ""name 2"",
                    ""subs"": {
                    ""37"": { ""name"":  ""is 37 in key""}
                    }
                }
                }
            }
            ";

            [DataContract]
            public class Root
            {
                [DataMember(Name ="id")]
                public string Id { get; set; }

                [DataMember(Name = "children")]
                public Dictionary<string,Child> Children { get; set; }
            }

            [DataContract]
            public class Child
            {
                [DataMember(Name = "name")]
                public string Name { get; set; }

                [DataMember(Name = "subs")]
                public Dictionary<int, Sub> Subs { get; set; }
            }

            [DataContract]
            public class Sub
            {
                [DataMember(Name = "name")]
                public string Name { get; set; }
            }

            public static void Test()
            {
                var array = System.Text.Encoding.UTF8.GetBytes(EXAMPLE);
                using (var mem = new System.IO.MemoryStream(array))
                {
                    mem.Seek(0, System.IO.SeekOrigin.Begin);
                    DataContractJsonSerializerSettings settings =
                       new DataContractJsonSerializerSettings();
                    settings.UseSimpleDictionaryFormat = true;

                    var ser = new DataContractJsonSerializer(typeof(Root), settings);
                    var data = (Root)ser.ReadObject(mem);
                    Console.WriteLine(data.Id);
                    foreach (var childKey in data.Children.Keys)
                    {
                        var child = data.Children[childKey];
                        Console.WriteLine(" Child: " + childKey + " " + child.Name);
                        foreach (var subKey in child.Subs.Keys)
                        {
                            var sub = child.Subs[subKey];
                            Console.WriteLine("   Sub: " + subKey + " " + sub.Name);
                        }
                    }
                }
            }
        }
    }

0

पर्याप्त रूप से, यदि आप डिफ़ॉल्ट मॉडल बाइंडरों का उपयोग करना चाहते हैं, तो ऐसा लगता है कि आपको फॉर्म POST जैसे संख्यात्मक सूचकांक मानों का उपयोग करना होगा।

इस लेख के निम्नलिखित अंश देखें http://msdn.microsoft.com/en-us/magazine/hh781022.aspx :

यद्यपि यह कुछ हद तक प्रतिवादपूर्ण है, JSON अनुरोधों की एक ही आवश्यकता है - वे भी, फॉर्म पोस्ट नामकरण सिंटैक्स का पालन करना चाहिए। उदाहरण के लिए, पिछले यूनिटप्रीस संग्रह के लिए JSON पेलोड लें। इस डेटा के लिए शुद्ध JSON सरणी सिंटैक्स को निम्न के रूप में दर्शाया जाएगा:

[ 
  { "Code": "USD", "Amount": 100.00 },
  { "Code": "EUR", "Amount": 73.64 }
]

हालाँकि, डिफ़ॉल्ट मान प्रदाता और मॉडल बाइंडर को JSON फॉर्म पोस्ट के रूप में डेटा का प्रतिनिधित्व करने की आवश्यकता होती है:

{
  "UnitPrice[0].Code": "USD",
  "UnitPrice[0].Amount": 100.00,

  "UnitPrice[1].Code": "EUR",
  "UnitPrice[1].Amount": 73.64
}

जटिल ऑब्जेक्ट संग्रह परिदृश्य शायद सबसे व्यापक रूप से समस्याग्रस्त परिदृश्यों में से एक है जो डेवलपर्स में चलते हैं क्योंकि सभी डेवलपर्स के लिए सिंटैक्स आवश्यक रूप से स्पष्ट नहीं है। हालांकि, एक बार जब आप जटिल संग्रह पोस्ट करने के लिए अपेक्षाकृत सरल वाक्यविन्यास सीख लेते हैं, तो इन परिदृश्यों से निपटना बहुत आसान हो जाता है।


0

मैं सुझाव दूंगा System.Runtime.Serialization.Jsonकि .NET 4.5 का हिस्सा है।

[DataContract]
public class Foo
{
   [DataMember(Name = "data")]
   public Dictionary<string,string> Data { get; set; }
}

फिर इसे इस तरह उपयोग करें:

var serializer = new DataContractJsonSerializer(typeof(List<Foo>));
var jsonParams = @"{""data"": [{""Key"":""foo"",""Value"":""bar""}] }";
var stream = new MemoryStream(Encoding.UTF8.GetBytes(jsonParams));

var obj = serializer.ReadObject(stream);
Console.WriteLine(obj);

धारावाहिक को कहां परिभाषित किया गया है?
bnieland

..और क्या एक श्रेणी 3MeasureModel है? Google पर कोई हिट नहीं।
bnieland

1
यह सिर्फ मॉडल वर्ग है जो मैं अपनी परियोजना के लिए धारावाहिक कर रहा हूं। यह माना जाता है कि फू क्लास है, लेकिन मैंने प्रोडक्शन कोड से पूरे सेक्शन को रिकॉप किया। तुम्हें मेरी फू कक्षा की तरह अपना खुद का बनाना चाहिए। मैंने इसे सरल बनाने के लिए फू का नाम बदल दिया। यह सिर्फ उन संपत्तियों या क्षेत्रों का एक वर्ग है, जिन्हें आप जेन्स और बैक पर क्रमबद्ध करना चाहते हैं।
Dan Csharpster

1
@DanCsharpster आपके कोड के सटीक कॉपी-अतीत के साथ, मुझे विंडोज फोन 8.1 सिल्वरलाइट पर मिलता है: `System.Security.SecurityException प्रकार का एक अपवाद System.ServiceModel.Web.ni.dll में हुआ था, लेकिन उपयोगकर्ता में संभाला नहीं था कोड अतिरिक्त जानकारी: डेटा अनुबंध प्रकार 'MyApp.Foo' की सदस्यता नहीं ली जा सकती क्योंकि सदस्य 'डेटा' सार्वजनिक नहीं है। सदस्य को सार्वजनिक करने से यह त्रुटि ठीक हो जाएगी। वैकल्पिक रूप से, आप इसे आंतरिक बना सकते हैं, और आंतरिक सदस्यों के क्रमांकन को सक्षम करने के लिए अपनी विधानसभा पर InternalsVoiceToAttribute विशेषता का उपयोग कर सकते हैं
Cœur

1
@DanCsharpster और संपत्ति को बदलते समय डेटा को एक सदस्य होने के लिए (बिना सेट?), मुझे प्राप्त होता है: प्रकार का पहला अपवाद अपवाद 'System.ArgumentException' System.ServiceModel.Web.ni.dk में हुआ। अतिरिक्त जानकारी: वस्तु प्रकार 'System.Object' को 'System.Collections.Generic.Dictionary`2 [System.String, System.String] टाइप करने के लिए परिवर्तित नहीं किया जा सकता है।
Cœur

0

किसी के लिए भी जो JSON को शब्दकोश में बदलने की कोशिश कर रहा है, उसमें से कुछ मूल्य प्राप्त करने के लिए। वहाँ एक आसान तरीका का उपयोग करNewtongsoft.JSON

using Newtonsoft.Json.Linq
...

JObject o = JObject.Parse(@"{
  'CPU': 'Intel',
  'Drives': [
    'DVD read/writer',
    '500 gigabyte hard drive'
  ]
}");

string cpu = (string)o["CPU"];
// Intel

string firstDrive = (string)o["Drives"][0];
// DVD read/writer

IList<string> allDrives = o["Drives"].Select(t => (string)t).ToList();
// DVD read/writer
// 500 gigabyte hard drive
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.