Android开发 解析JSON数据格式 如何去掉JSON数据文件的BOM头

本文详细介绍Android开发中JSON数据的解析方法,包括解析Object与Array的不同情况,并提供代码示例。同时,介绍了处理UTF-8 BOM头导致的解析异常问题及解决方案。

Android开发中如何解析JSON数据格式?

1.JSON解析
     (1).解析Object之一:

1 {"url":"http://www.ideaex.net"}

  解析方法:

1 JSONObject demoJson = new JSONObject(jsonString);
2 String url = demoJson.getString("url");

  (2).解析Object之二:

1 {"name":"android","name":"iphone"}

  解析方法:

1 JSONObject demoJson = new JSONObject(jsonString);
2 String name = demoJson.getString("name");
3 String version = demoJson.getString("version");
4 System.out.println("name:"+name+",version:"+version);

     (3).解析Array之一:

1 {"number":[1,2,3]}

   解析方法:

1 JSONObject demoJson = new JSONObject(jsonString);
2 JSONArray numberList = demoJson.getJSONArray("number");
3 for(int i=0; i<numberList.length(); i++){
4     //因为数组中的类型为int,所以为getInt,其他getString,getLong同用
5     System.out.println(numberList.getInt(i));
6 }

  (4).解析Array之二:

1 {"number":[[1],[2],[3]]}

  解析方法:

1 //嵌套数组遍历
2 JSONObject demoJson = new JSONObject(jsonString);
3 JSONArray numberList = demoJson.getJSONArray("number");
4 for(int i=0; i<numberList.length(); i++){
5       //获取数组中的数组
6       System.out.println(numberList.getJSONArray(i).getInt(0));
7 }

  (5).解析Object和Array:

1 {"mobile":[{"name":"android"},{"name":"iphone"}]}

  解析方法:

1 JSONObject demoJson = new JSONObject(jsonString);
2 JSONArray numberList = demoJson.getJSONArray("mobile");
3 for(int i=0; i<numberList.length(); i++){
4       System.out.println(numberList.getJSONObject(i).getString("name"));
5 }

  所以,我们发现get后面接着的是你想要的得到的结果的类型:getType,这个对理解很有帮助。
     (6).使用optType:
      上面的例子,使用getType在碰到查找不到节点的时候,会抛出异常。
      如果使用optType,找不到节点,则返回null或者默认值。

1 //无url节点,抛出异常
2 String url = demoJson.getString("url");
3 //无url节点,返回空,如果为基本类型,则返回默认值
4 String url = demoJson.optString("url");

  (7).UTF-8的BOM头导致解析JSON异常的问题
      到json文件保存为utf-8的时候,在windows平台下,会产生bom头"EF BB EF"字节在文本的最前面(需要用十六进制工具打开才能看的到)。
      有两种解决方法:
      a.使用UltraEdit打开json文件, 另存为的时候,选择格式UTF-8,无BOM头,如果还不行,在用记事本打开,另存为UTF-8下,多试几次就可以了。
      b.使用代码处理,截取json主体内容:

1 String jsonString = getJsonString();
2 jsonString = jsonString.substring(jsonString.indexOf("{"),jsonString.lastIndexOf("}")+1);

2.JSON必知
     (1).JSON是一种轻量级的数据交换格式
     (2).JSON基于两种数据结构:Object和Array。其中Object是“名称/值”对的集合。
     (3).对象:大括号,每一组string-value结合以","分隔,string和value以冒号分隔。[转载]Android开发 <wbr>解析JSON数据格式 <wbr>如何去掉JSON数
 

     (4).数组:[转载]Android开发 <wbr>解析JSON数据格式 <wbr>如何去掉JSON数

     (5).string由双引号包围的任意数量Unicode字符的集合,使用反斜线转义。[转载]Android开发 <wbr>解析JSON数据格式 <wbr>如何去掉JSON数

     (6).value可以是双引号括起来的字符串(string)、数值(number)、truefalse null、对象(object)或者数组(array)。这些结构可以嵌套。[转载]Android开发 <wbr>解析JSON数据格式 <wbr>如何去掉JSON数

     (7).空白可以加入到任何符号之间,包括空格,tab,回车,换行等。
     (8).举例:
       a.Object实例:

01 {
02      "Image": {
03       "Width" 800,
04       "Height": 600,
05       "Title" "View from 15th Floor",
06       "Thumbnail": {
07           "Url"   "http://www.example.com/image/481989943",
08           "Height": 125,
09           "Width" "100"
10       },
11       "IDs": [116, 943, 234, 38793]
12     }
13 }

         b.Array实例:

01 [
02    {
03       "precision""zip",
04       "Latitude" 37.7668,
05       "Longitude": -122.3959,
06       "Address"  "",
07       "City"     "SAN FRANCISCO",
08       "State"    "CA",
09       "Zip"      "94107",
10       "Country"  "US"
11    },
12    {
13       "precision""zip",
14       "Latitude" 37.371991,
15       "Longitude": -122.026020,
16       "Address"  "",
17       "City"     "SUNNYVALE",
18       "State"    "CA",
19       "Zip"      "94085",
20       "Country"  "US"
21    }
22 ]



Android Studio中,如果你需要从MySQL数据库获取UTF-8编码的数据,并将其解析JSON返回给前端,通常会经历以下几个步骤: 1. **连接到MySQL**: 首先,你需要通过`JDBC`(Java Database Connectivity)驱动程序如`mysql-connector-java`连接到MySQL服务器。确保配置了正确的URL、用户名、密码以及字符集设置(默认为UTF-8)。 ```java String url = "jdbc:mysql://localhost:3306/your_database"; String user = "username"; String password = "password"; Connection conn = DriverManager.getConnection(url, user, password); conn.setCharacterEncoding("UTF-8"); ``` 2. **执行查询**: 使用`Statement`, `PreparedStatement`或`JdbcTemplate`等工具执行SQL查询。 3. **处理结果**: 获取到的结果集应该也是UTF-8编码的,可以直接转换为JSON。你可以使用`org.json`库将结果集转化为JSON对象或字符串。 ```java ResultSet rs = stmt.executeQuery("SELECT * FROM your_table"); JSONArray jsonArray = new JSONArray(); while (rs.next()) { JSONObject jsonObject = new JSONObject(); // 将字段值添加到JSONObject jsonObject.put("field1", rs.getString("utf8_field")); jsonArray.put(jsonObject); } String jsonString = jsonArray.toString(); ``` 4. **发送JSON**: 最后,将JSON字符串发送给前端,通常通过HTTP响应或WebSocket等方式。 **注意事项**: - 在处理字符串时,确保所有涉及到输入和输出的地方都使用UTF-8编码。 - 如果从数据库获取的是BOM(Byte Order Mark)开的文本,记得移除它,因为这可能会干扰JSON解析
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值