[Android]使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换

目录

1.JSON是什么?

2.JSON数据格式

3.相关API

1.JSONObject:

   2.Gson

  4.使用JSONObject

将json格式的字符串{}转换为kotlin对象

将json格式的字符串[]转换为kotlin对象的List

5.使用GSON

要先添加依赖

将json格式的字符串{}转换为kotlin对象 

 将json格式的字符串[]转换为kotlin对象的List

将kotlin对象转换为json字符串{}

将kotlin对象的List转换为json字符串[]

6.使用Map封装json对象key特别情况


1.JSON是什么?

  • JSON(JavaScript Object Notation)是一种轻量级的数据交换格式
  • 本质就是具有特定格式的字符串
  • JSON数据已经是客户端与服务端交互的最常用的选择,已经很少使用xml来进行数据交互了

JSON比起XML的优势和缺点:

优势:JSON的体积更小,在网络上传输的时候更省流量。

缺点:语义性较差,看起来不如XML直观。 

如何获得JSON格式的数据

对于刚开始学习JSON的朋友,总会遇到一个问题:如何获得JSON格式的数据,如果你现在有同样的问题,可以试试看我的另一篇博客http://t.csdn.cn/JNaXQ里面有详细的介绍。

2.JSON数据格式

  • 整体结构

           Json数组:[]

           Json对象:{}

  • Json数组的结构:[value1,value2,value3]
  • Json对象的结构:{key1:value1,key2:value2,key3:value3}
  • key的数据类型:字符串
  • value的数据类型

            数值  字符串 null  json数组 json对象

  • 例子

        [1,"abcd",[{"a",1}],{"b":2,"c":[]}]

3.相关API

1.JSONObject:

  • JsonObject:json对象{}

           JSONObject( json:String):将json字符串解析为json对象

           Xxx.getXxx(name:String):根据name,在json对象中得到对应的Value

  • JsonArray:json数组[]

       JSONArray(json:String ):将json字符串解析为json数组

        length():得到json数组中元素的个数

        Xxx.getJSONObject(index:int ):根据下标得到json数组中对应的元素数据

   2.Gson

  • Gson:能解析json数据的类

       Gson():构造对象的方法

       toJson(src:Object):将对象转换为对应格式的json字符串

       fromJson(json:String,typeOfT:Type):T:解析JSon字符串,得到对象

  • TypeToken<T>:用来得到Type的类

       protected TypeToken():受保护的构造方法

       getType():Type:得到类型对象

  4.使用JSONObject

json格式的字符串{}转换为kotlin对象

1.将json字符串封装成JSONObject对象

2.从对象中根据key得到对应的value

private fun JsonToObject(jsonData:String){
        try {
            //1.将json字符串封装成JSONObject对象
            val jsonObject:JSONObject= JSONObject(jsonData)
            //2.从对象中根据key得到对应的value
            val id:Int=jsonObject.getInt("id")
            val name:String=jsonObject.getString("name")
            val price:Double=jsonObject.getDouble("price")
            val imagePath:String=jsonObject.getString("imagePath")
            Log.d("data","id is $id")
            Log.d("data","name is $name")
            Log.d("data","price is $price")
            Log.d("data","imagePath is $imagePath")
        }catch (e:Exception){
            e.printStackTrace()
        }
}

json格式的字符串[]转换为kotlin对象的List

1.将json字符串包装JSONArray对象

2.遍历JSONArray对象所以元素(JSONObject),并将每个元素封装为shopInfo,并添加到List

private fun JsonToList(jsonData:String){
        try {
            val list= ArrayList<ShopInfo>()
            //1.将json字符串包装JSONArray对象
            val jsonArray= JSONArray(jsonData)
            //2.遍历JSONArray对象所以元素(JSONObject),并将每个元素封装为shopInfo,
             //并添加到List
            for(i in 0 until jsonArray.length()){
                val jsonObject=jsonArray.getJSONObject(i)
                //从对象中根据key得到对应value
                val id:Int=jsonObject.getInt("id")
                val name:String=jsonObject.getString("name")
                val price:Double=jsonObject.getDouble("price")
                val imagePath:String=jsonObject.getString("imagePath")
                Log.d("data","id is $id")
                Log.d("data","name is $name")
                Log.d("data","price is $price")
                Log.d("data","imagePath is $imagePath")
                list.add(ShopInfo(id,name,price,imagePath))
            }
        }catch (e:Exception) {
            e.printStackTrace()
        }
}

5.使用GSON

要先添加依赖

implementation 'com.google.code.gson:gson:2.8.5'

json格式的字符串{}转换为kotlin对象 

 private fun JsonToObjectGson(jsonData:String){
        val gson=Gson()
        val shopInfo=gson.fromJson(jsonData,ShopInfo::class.java)
 }

 将json格式的字符串[]转换为kotlin对象的List

 private fun JsonToListGson(jsonData:String){
        val gson=Gson()
        val typeOf=object:TypeToken<List<ShopInfo>>(){}.type
        val list=gson.fromJson<List<ShopInfo>>(jsonData,typeOf)
        for (a in list){
            Log.d("data","id is $a.id")
            Log.d("data","name is $a.name")
            Log.d("data","price is $a.price")
            Log.d("data","imagePath is $a.imagePath")
        }
    }

kotlin对象转换为json字符串{}

 private fun ObjectToJson(){
        val info:ShopInfo= ShopInfo(4,"小名",11.0,"http://www.ddd.com")
        val json:String=Gson().toJson(info)
        Log.d("data",json)
    }

kotlin对象的List转换为json字符串[]

private fun ListToJson(){
        val list=ArrayList<ShopInfo>()
        list.add(ShopInfo(4,"小名",11.0,"http://www.ddd.com"))
        list.add(ShopInfo(5,"小星",21.0,"http://www.eee.com"))
        val json:String=Gson().toJson(list)
        Log.d("data",json)
 }

6.使用Map封装json对象key特别情况

当json对象的key不符合变量的命名法则,比如:my name(变量中有空格)或者2,无法在ShopInfo类中添加这个成员变量,该怎么解决?

我们可以把json对象转换成Map

 private fun JsonToMap(jsonString:String) {
        val json=Gson()
        val typeOf=object :TypeToken<Map<String,Objects>>(){}.type
       val map:Map<String,Objects> = json.fromJson(jsonString,typeOf)
        Log.d("data",map.toString())
 }

  • 17
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 29
    评论
可以通过以下步骤实现 ResultSet 与 JSON 相互转化: 1. 将 ResultSet 转化为 List<Map<String, Object>> 对象。 2. 使用 Gson 将 List<Map<String, Object>> 对象转化为 JSON 格式的字符串。 3. 使用 GsonJSON 格式的字符串转化为 List<Map<String, Object>> 对象。 4. 将 List<Map<String, Object>> 对象转化为 ResultSet 对象。 以下是 Java 代码示例: ```java import com.google.gson.Gson; import java.sql.*; import java.util.*; public class ResultSetToJson { public static void main(String[] args) throws SQLException { // 获取数据库连接 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?useSSL=false", "root", "password"); // 执行 SQL 查询语句 Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM users"); // 将 ResultSet 转化为 List<Map<String, Object>> 对象 List<Map<String, Object>> resultList = new ArrayList<Map<String, Object>>(); ResultSetMetaData metaData = rs.getMetaData(); int columnCount = metaData.getColumnCount(); while (rs.next()) { Map<String, Object> map = new HashMap<String, Object>(); for (int i = 1; i <= columnCount; i++) { String columnName = metaData.getColumnLabel(i); Object value = rs.getObject(columnName); map.put(columnName, value); } resultList.add(map); } // 使用 Gson 将 List<Map<String, Object>> 对象转化为 JSON 格式的字符串 Gson gson = new Gson(); String json = gson.toJson(resultList); System.out.println(json); // 使用 GsonJSON 格式的字符串转化为 List<Map<String, Object>> 对象 List<Map<String, Object>> resultList2 = gson.fromJson(json, List.class); // 将 List<Map<String, Object>> 对象转化为 ResultSet 对象 ResultSetMetaData metaData2 = rs.getMetaData(); ResultSet rs2 = new ResultSetImpl(resultList2, metaData2); while (rs2.next()) { System.out.println(rs2.getInt("id") + " " + rs2.getString("name")); } // 关闭 ResultSet、Statement 和 Connection 对象 rs.close(); stmt.close(); conn.close(); } } class ResultSetImpl implements ResultSet { private List<Map<String, Object>> resultList; private ResultSetMetaData metaData; private int rowIndex = -1; public ResultSetImpl(List<Map<String, Object>> resultList, ResultSetMetaData metaData) { this.resultList = resultList; this.metaData = metaData; } @Override public boolean next() throws SQLException { rowIndex++; return rowIndex < resultList.size(); } @Override public String getString(String columnLabel) throws SQLException { Object value = resultList.get(rowIndex).get(columnLabel); return value == null ? null : value.toString(); } // 实现 ResultSet 接口中的其他方法 } ``` 需要注意的是,由于 ResultSet 接口中的方法较多,以上代码仅实现了部分方法,具体实现可根据需求进行扩展。另外,由于 ResultSet 接口是只读的,因此在实现 ResultSet 接口时不能包含更新、插入或删除等方法
评论 29
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值