posts - 156,  comments - 601,  trackbacks - 0
          svenson是一個用于生成和解析JSON數據格式的Java5開源類庫。它能夠將JSON數據集轉換成Java對象或相反的操作。

          下面是一些示例:

          Svenson offers you the possibility to generate JSON datasets from your java classes being a nested graph of:

          • POJOs
          • Java Beans
          • Arrays
          • Collections
          • Maps

          In the most simple case you can just do a

          import org.svenson.JSON;



          ...







          String json = JSON.defaultJSON().forValue( yourObjects );

          you can also generate JSON while ignoring certain properties:

          import org.svenson.JSON;



          ...







          String json = JSON.defaultJSON().forValue( yourObjects, Arrays.asList("foo","bar"));

          This would generate JSON for "yourObjects" while ignoring all properties named "foo" and "bar" in all beans.

          @JSONProperty

          The org.svenson.JSONProperty annotation allows you to define another JSON property name for your properties, make JSON ignore your properties completely or ignore them if they are null.

          import org.svenson.JSON;



          import org.svenson.JSONProperty;







          public class MyBean



          {



             
          private String foo,bar,baz;

             
          @JSONProperty("notFoo")
             
          public String getFoo()
             
          {
               
          return foo;
             
          }

             
          @JSONProperty(ignoreIfNull = true)
             
          public String getBar()
             
          {
                 
          return foo;
             
          }

             
          @JSONProperty(ignore = true)
             
          public String getBaz()
             
          {
                 
          return foo;
             
          }

          }

          Here the foo property would be generated as "notFoo" property in JSON, the "bar" property would be ignored if it is null, and the "baz" property would be ignored completely.

          JSONable

          If your classes implement the org.svenson.JSONable, they can provide their own JSON representation.

          import org.svenson.JSON;



          import org.svenson.JSONable;







          public class MyClass implements JSONable



          {



             
          private String member;



             
          ...



             
          public String toJSON()



             
          {



                   
          return JSON.defaultJSON().quote(this.member);



             
          }



          }

          Here MyClass would just generate one of its members as JSON string. As you can see, you can use the JSON class to help you implementing toJSON().

          JSONifier

          A JSONifier is a class that can convert another class into JSON. It needs to implement org.svenson.JSONifier.

          import org.svenson.JSON;



          import org.svenson.JSONifier;







          public class MyJSONifier implements JSONifier



          {



             
          public String toJSON(Object o)



             
          {



                   
          MyClass myClass = (MyClass)o;



                   
          return JSON.defaultJSON().quote(myClass.getMember());



             
          }



          }

          This would be a simple JSONifier that turns instances of MyClass into JSON by replacing them with one of its members. To use this JSONifier you have to register it in your own JSON instance.

          import org.svenson.JSON;



             
          ...



             
          // assume myClassInstance is an instance of MyClass



              JSON json
          = new JSON();



              json
          .registerJSONifier(MyClass.class, new MyJSONifier());







             
          String output = json.forValue( myClassInstance);

          svenson 官方網址:http://code.google.com/p/svenson/

          Good Luck!
          Yours Matthew!
          posted on 2008-12-29 21:35 x.matthew 閱讀(3130) 評論(0)  編輯  收藏 所屬分類: 最新開源動態Best Practise(JDK API)
          主站蜘蛛池模板: 长岭县| 泰州市| 朝阳县| 兴义市| 水城县| 淮滨县| 巴青县| 盘山县| 万年县| 灵川县| 新源县| 鸡西市| 吉安县| 巩义市| 安吉县| 东宁县| 二连浩特市| 竹山县| 平和县| 临猗县| 柯坪县| 驻马店市| 安义县| 综艺| 文昌市| 昆山市| 通海县| 防城港市| 启东市| 班玛县| 涟水县| 乐昌市| 天祝| 丹阳市| 新乡市| 丹巴县| 新昌县| 连城县| 都昌县| 石城县| 宁波市|