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

今天寫代碼時,還遇到瞭如下的錯誤消息:

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位置的字符處就出現異常!

 

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *