终于找到一模一样的现象了。
在android2.3上json出现此问题,提示错误“JSONException: Value of type java.lang.String cannot be converted to JSONObject”,而4.0上没问题。
部分错误log如下:
1 12 - 18 20 : 23 : 27.389 : W / System.err( 12927 ): org.json.JSONException: Value of type java.lang.String cannot be converted to JSONObject 2 12 - 18 20 : 23 : 27.389 : W / System.err( 12927 ): at org.json.JSON.typeMismatch(JSON.java: 107 ) 3 12 - 18 20 : 23 : 27.389 : W / System.err( 12927 ): at org.json.JSONObject. < init > (JSONObject.java: 158 ) 4 12 - 18 20 : 23 : 27.389 : W / System.err( 12927 ): at org.json.JSONObject. < init > (JSONObject.java: 171 )
该异常有 json 文件编码所引起的,所以千万不要使用 记事本 编辑 json 文件,而应选择其他文本编辑器,如 EditPlus ,并注意保存编码格式为 UTF-8,否则可能产生中文乱码。
用记事本编辑后,即使 另存为 UTF-8 形式,也会产生乱码,因为保存在为 UTF-8 + BOM 编码
由于我是将 json 文件放在 tomcat ,进行读取的。从而导致该问题产生。
原因是服务器返回的数据UTF-8带有BOM头,含有BOM头的数据会多出来三个字节 efbbbf。
这样在解析json的时候就会有问题,android4.0对此已经做了处理,所以没有报错。
1 // android 2.3 2 public JSONTokener(String in) { 3 this .in = in; 4 } 5 6 // android 4.0 7 public JSONTokener(String in) { 8 // consume an optional byte order mark (BOM) if it exists 9 if (in != null && in.startsWith( " \ufeff " )) { 10 in = in.substring( 1 ); 11 } 12 this .in = in; 13 }
转自:http://my.oschina.net/mstian/blog/185716