新浪微博是我最早寫入到項目中去的,利用的是它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);估計是作者在編寫時的一個失誤。
然後在你的程式中輸出錯誤資訊就可以了:
weiboRunner.request(AAuthTestActivity.this, url, bundle, Utility.HTTPMETHOD_POST, new com.weibo.net.AsyncWeiboRunner.RequestListener(){ @Override public void onComplete(String arg0) { // TODO Auto-generated method stub Log.e("sina_complete",arg0.toString()); } @Override public void onError(WeiboException arg0) { // TODO Auto-generated method stub Log.e("sina_error",arg0.toString()); } @Override public void onIOException(IOException arg0) { // TODO Auto-generated method stub Log.e("sina_IOException",arg0.toString()); } });
我的輸出資訊是:{"error":"repeat content!","error_code":20019,"request":"/2/statuses/upload.json"}。這樣你就可以在http://open.weibo.com/wiki/Help/error 找到你的錯誤原因了。
希望對大家有協助!