Androd學習筆記——新浪微博Android SDK——如何打印出5位錯誤碼


  新浪微博是我最早寫入到項目中去的,利用的是它Java SDK。但是最近整理各個SDK的時候發現——新浪微博對新應用要求使用OAuth2.0,所以我只能利用它的Android SDK重新寫入到程序中。其實改寫程序還是比較簡單的,只要根據它的Sample程序進行修改就行了。但是這個過程中碰到了一個問題。

  問題描述:獲得Access Token之后,進行圖文微博的發送,但是每次只有第一次發送成功,獲得Log信息:“{"created_at":"Wed Mar 21 11:12:52 +0800……”。但是接下來我繼續發送的話,卻得到:“com.weibo.net.WeiboException: HTTP/1.1 400 ”。我在新浪論壇問了一下,版主要求我提供5位錯誤碼。我表示一頭霧水,難道要我進行抓包。。。

  問題解決:其實我們仔細觀察會發現,其實我們兩次得到的Log信息其實是不一樣的。至少第二次也應該是:“{……}”的。所以我就懷疑是SDK內部寫錯。經過我的調試,最后我們的辦法是:

  在SDK的Utility.java的第335行:throw new WeiboException(String.format(status.toString()), statusCode);
改成:throw new WeiboException(result, statusCode);估計是作者在編寫時的一個失誤。


  然后在你的程序中輸出錯誤信息就可以了:

 1 weiboRunner.request(AAuthTestActivity.this, url, bundle, Utility.HTTPMETHOD_POST, new  com.weibo.net.AsyncWeiboRunner.RequestListener(){
2
3 @Override
4 public void onComplete(String arg0) {
5 // TODO Auto-generated method stub
6 Log.e("sina_complete",arg0.toString());
7 }
8
9 @Override
10 public void onError(WeiboException arg0) {
11 // TODO Auto-generated method stub
12 Log.e("sina_error",arg0.toString());

13 }
14
15 @Override
16 public void onIOException(IOException arg0) {
17 // TODO Auto-generated method stub
18 Log.e("sina_IOException",arg0.toString());
19 }
20
21 });

 

  我的輸出信息是:{"error":"repeat content!","error_code":20019,"request":"/2/statuses/upload.json"}。這樣你就可以在http://open.weibo.com/wiki/Help/error 找到你的錯誤原因了。

  希望對大家有幫助!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM