Google GSON GsonBuilder().setDateFormat("yyyy-MM-dd HH:mm:ss")不能格式化Data

Google GSON GsonBuilder().setDateFormat("yyyy-MM-dd HH:mm:ss")不能格式化Data

在項目中遇到問題,數據庫中保存的時間類型爲datetime(MySQL),實體類中對應數據類型爲java.sql.Date,利用GsonBuilder().setDateFormat("yyyy-MM-dd HH:mm:ss")構造gson對象向客戶端輸出json字符串。忽一日客戶端接收到的日期字段值爲中文時間,大驚,徹查,疑爲實體類中的數據類型不適合,導致Hibernate中的timestamp部分信息丟失,嘗試着將實體類中類型改爲java.sql.Timestamp,再試,成功。

另搜索到網上一哥們的其他解法,如下:

 首先創建一個類型適配器

  1. public class TimestampTypeAdapter implements JsonSerializer<Timestamp>, JsonDeserializer<Timestamp>{  
  2.      private final DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");      
  3.      public JsonElement serialize(Timestamp ts, Type t, JsonSerializationContext jsc) {      
  4.          String dfString = format.format(new Date(ts.getTime()));      
  5.          return new JsonPrimitive(dfString);      
  6.      }      
  7.      public Timestamp deserialize(JsonElement json, Type t, JsonDeserializationContext jsc) throws JsonParseException {      
  8.          if (!(json instanceof JsonPrimitive)) {      
  9.              throw new JsonParseException("The date should be a string value");      
  10.          }      
  11.       
  12.          try {      
  13.              Date date = format.parse(json.getAsString());      
  14.              return new Timestamp(date.getTime());      
  15.          } catch (ParseException e) {      
  16.              throw new JsonParseException(e);      
  17.          }      
  18.      }      
  19.  }  

 

應用類型適配器

  1. GsonBuilder gsonBuilder = new GsonBuilder();  
  2. gsonBuilder.setDateFormat("yyyy-MM-dd hh:mm:ss");  
  3. gsonBuilder.registerTypeAdapter(Timestamp.class,new TimestampTypeAdapter());  
  4. Gson GSON = gsonBuilder.create();  
  5. String json = GSON.toJson(new Timestamp((new Date()).getTime()));

發佈了28 篇原創文章 · 獲贊 8 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章