org.json.JSONException: End of input at character 0 of

时间:2022-10-29 14:28:49

今天写代码时,还遇到了如下的错误消息:

04-08 21:55:22.792: W/System.err(10665): org.json.JSONException: End of input at character 0 of 
04-08 21:55:22.802: W/System.err(10665): at org.json.JSONTokener.syntaxError(JSONTokener.java:446)
04-08 21:55:22.802: W/System.err(10665): at org.json.JSONTokener.nextValue(JSONTokener.java:93)
04-08 21:55:22.802: W/System.err(10665): at org.json.JSONArray.<init>(JSONArray.java:87)
04-08 21:55:22.812: W/System.err(10665): at org.json.JSONArray.<init>(JSONArray.java:103)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.service.GetNews.GetJSON(GetNews.java:65)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.service.GetNews.getNewsListByJSON(GetNews.java:48)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.news.NewsActivity.fillListView(NewsActivity.java:29)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.news.NewsActivity.onCreate(NewsActivity.java:24)
04-08 21:55:22.812: W/System.err(10665): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
04-08 21:55:22.812: W/System.err(10665): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
04-08 21:55:22.812: W/System.err(10665): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
04-08 21:55:22.812: W/System.err(10665): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
04-08 21:55:22.822: W/System.err(10665): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
04-08 21:55:22.822: W/System.err(10665): at android.os.Handler.dispatchMessage(Handler.java:99)
04-08 21:55:22.822: W/System.err(10665): at android.os.Looper.loop(Looper.java:123)
04-08 21:55:22.822: W/System.err(10665): at android.app.ActivityThread.main(ActivityThread.java:3683)
04-08 21:55:22.832: W/System.err(10665): at java.lang.reflect.Method.invokeNative(Native Method)
04-08 21:55:22.832: W/System.err(10665): at java.lang.reflect.Method.invoke(Method.java:507)
04-08 21:55:22.832: W/System.err(10665): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-08 21:55:22.832: W/System.err(10665): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-08 21:55:22.832: W/System.err(10665): at dalvik.system.NativeStart.main(Native Method)

我们先直译一下错误消息的意思:在输入端字符0结尾处抛出了JSONException;

后然,发现了错误的原因:

/**
*    读取 流数据 
* @param input
* @return
* @throws Exception
*/

public static byte[] read(InputStream input) throws Exception {
ByteArrayOutputStream out =new ByteArrayOutputStream(); 
byte[] data =new byte[1024];
int len =0;
while((len=input.read(data))!=-1){
out.write(data, 0, 0); //原本应该是out.write(data, 0, len);,但当时用了快捷键,打成了0,就抛出了如上的异常消息
}
out.close(); 
return out.toByteArray();
}

看了上面的代码,我想你也知道我抛出这个异常的原因了吧;再看看下面的代码:

/***
*  从服务器 返回JSON 数据  并在这里进行解析
* @param input
* @return
* @throws Exception 
*/

private static List<News> GetJSON(InputStream input) throws Exception {
List<News> list =new ArrayList<News>();
byte[] data =StreamTool.read(input);
String json =new String (data);  // 从 服务器 传过来的数据   产用的编码就是  utf-8   这里就不写了
JSONArray array =new JSONArray(json);    
for(int i =0 ; i<array.length();i++){
JSONObject jsonObject =array.getJSONObject(i);  
News news =new News();
news.setNid(jsonObject.getInt("id"));
news.setNauthor(jsonObject.getString("author"));
news.setNtitle(jsonObject.getString("title"));
list.add(news);
}
return list;
}

我当时调用了第一个方法read(InputStream input)方法,因为不小心打错了代码,该方法返回的值肯定是什么字节,那么在解析JSON 肯定是在索引为0位置的字符处就出现异常!