Java의 JSON 형식 변환 라이브러리 GSON의 초기 사용 노트

3376 단어 JavaGSON
이제 Java 객체를 JSON으로 변환할 수 있는 소스 오픈 프로젝트가 있습니다.그러나 대부분의 항목은 클래스 파일에 자바 주석을 넣으라고 요구하지만, 원본 코드를 바꿀 수 없을 때는 할 수 없다.또한 Java 범주도 지원되지 않습니다.하지만 Gson은 이 두 가지를 자신의 중요한 디자인 목표로 삼았다.
특징:
  • toJson()과 fromJson() 방법을 사용하면 Java 객체에서 JSON으로의 상호 변환을 쉽게 완성할 수 있습니다.
  • 미리 존재하는 수정할 수 없는 객체를 JSON과 서로 변환할 수 있습니다.
  • 는 Java 범용 사용을 지원합니다.
  • 대상의 개성화된 표현 형식(representation)을 허용한다.
  • 은 각종 복잡(심계승 차원 구조와 대량의 사용 범용 유형을 가진) 대상을 지원한다.
  • Gson의 응용은 주로 toJson과fromJson 두 가지 변환 방법이다. 이러한 대상 변환을 사용하기 전에 먼저 좋은 대상의 클래스와 그 구성원을 만들어야 JSON 문자열을 대응하는 대상으로 성공적으로 변환할 수 있다.
    
    public class GsonUtil {
      public static Gson gson;
      /**Json JavaBean**/
      public static final int JSON_JAVABEAN=0x10001;
      /**Json List<T>**/
      public static final int JSON_LIST=0x10002;
      /**Json Map<T>**/
      public static final int JSON_MAP=0x10004;
    
      /**
       *  Json 
       * @param object  Json 
       * @return String:Json 
       */
      public static String convertObject2Json(Object object) {   
        gson=new Gson();      
        return gson.toJson(object);
      } 
      /**
       *  Json Java 
       * @param inputStream  Java inputStream
       * @param javaBean List Map javaBean
       * @param convertFlag  
       * @return Object:Java 
       */
      public static Object convertJson2Object(InputStream inputStream,Class<?>javaBean ,int convertFlag) {    
        gson=new Gson();  
        Object object=null;
    //   String json=inputStream2String(inputStream);
        BufferedReader reader=intputStream2BufferedReader(inputStream);  
        Type type=getType(javaBean,convertFlag);  
        object=gson.fromJson(reader,type);     
        return object;
      }
      /**
       *  
       * @param javaBean
       * @param convertFlag
       * @return
       */
      private static Type getType(Class<?> javaBean,int convertFlag) {   
        Type type=null;
        switch (convertFlag) {
        case JSON_LIST:
          if (javaBean.equals(News.class)) {//Json List 
            type=new TypeToken<List<News>>(){}.getType();
          }
          break;
        case JSON_MAP:
          if (javaBean.equals(News.class)) {//Json Map 
            type=new TypeToken<Map<String,News>>(){}.getType();
          }
          break;    
        case JSON_JAVABEAN://Json JavaBean
          type=javaBean;
          break;    
        }   
        return type; 
      }
      /**
       *  InputStream BufferedReader
       * @param inputStream
       * @return
       */
      private static BufferedReader intputStream2BufferedReader(InputStream inputStream) {   
        return new BufferedReader(new InputStreamReader(inputStream));  
      }
    }
    
    
    코드 분석:
    Json을 대상으로 변환할 때 위의 코드는 서버에서 입력 흐름을 가져온 다음 입력 흐름을 BufferedReader 대상으로 봉인한 다음fromJson () 방법을 통해 Json을 Java 대상으로 변환합니다.
    Gson의fromJson() 방법의 첫 번째 매개 변수는 String, JsonElement, Reader 형식의 매개 변수를 지원하며 필요에 따라 선택할 수 있습니다.fromJson() 메서드의 두 번째 매개변수는 Type 및 Class 지원유형 매개변수, Json을 JavaBean으로 변환할 때 Class 사용 가능매개 변수, 즉 자바빈에 대응하는 자바빈을 사용합니다.calss는 두 번째 매개 변수입니다.Json을 List 범주로 변환해야 할 때,Map 범주로 변환할 때 TypeToken을 사용하여 두 번째 파라미터를 Type 형식으로 변환해야 합니다(TypeToken은 gson이 제공하는 데이터 형식 변환기로서 각종 데이터 집합 형식 변환을 지원할 수 있습니다).

    좋은 웹페이지 즐겨찾기