android使用appache httpclient混淆后錯誤排除總結(jié)

android使用appache httpclient混淆后錯誤排除總結(jié)

引用出處:http://blog.csdn.net/chenrunhua/article/details/50054225

android上使用appache httpclient上傳文件時報一下錯誤:

[html]view plaincopy

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?org.apache.http.client.ClientProtocolException

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:756)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:519)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:497)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cloudapm.agent.android.instrumentation.HttpInstrumentation.execute(SourceFile:188)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.ecloud.netapi.a.m.a(SourceFile:130)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.ecloud.f.j.dY(SourceFile:160)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.e.dX(SourceFile:52)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.d.run(SourceFile:459)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.b.dS(SourceFile:316)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.b.a(SourceFile:14)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.c.run(SourceFile:62)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?java.lang.Thread.run(Thread.java:864)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:??Caused?by:?org.apache.http.client.NonRepeatableRequestException:?Cannot?retry?request?with?a?non-repeatable?request?entity

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:427)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:754)

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:519)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:497)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cloudapm.agent.android.instrumentation.HttpInstrumentation.execute(SourceFile:188)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.ecloud.netapi.a.m.a(SourceFile:130)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.ecloud.f.j.dY(SourceFile:160)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.e.dX(SourceFile:52)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.d.run(SourceFile:459)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.b.dS(SourceFile:316)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.b.a(SourceFile:14)?

11-20?12:49:59.572?7360-22466/com.cn21.ecloud?D/d:?????at?com.cn21.android.b.c.run(SourceFile:62)?

代碼如下

[html]view plaincopy

RandomAccessFilefile=newRandomAccessFile(localFile,?"r");

//?僅上傳未完成的文件內(nèi)容

file.seek(status._size);

InternalFileStreamfs=newInternalFileStream(new?FileInputStream(

file.getFD()),?status._size,?observer);

InputStreamEntityentity=newInputStreamEntity(fs,?fileLength

-?status._size);

request.setEntity(entity);

DLog.d(TAG,"entity?is?repeatable???=?"?+?entity.isRepeatable());

DLog.write2File(TAG,?"entity?is?repeatable???=?"?+?entity.isRepeatable(),?DLog.LOG_PATH_TRANSFER);

if(ConstantConfig.DEBUG){

dumpRequest(request,?null);

}

try?{

HttpResponseresponse=mHttpClient.execute(request);

InternalFileStream是繼承FilterInputStream類汞舱,實現(xiàn)進度得回調(diào)梆掸;

問題的表現(xiàn):在混淆中购披,上傳文件時就會報這個問題;不混淆則一直沒有沒有問題;

解決:

1.一開始被這個問題領(lǐng)向錯誤的方向喷舀;因為是混淆出問題,不混淆則一直沒問題,所以在查混淆是否導(dǎo)致問題這個方向上:到最后添加了所有的類都不混淆的也不能解決問題

-keep class **{*;}

2.查看錯誤的log:貌似是NonRepeatableRequestException是不可重讀的問題茫虽,

用filebody不好替換;

3.用HttpURLConnection替換http client既们,最后報錯如下:

[html]view plaincopy

11-25?18:17:41.783?26180-26378/com.cn21.ecloud?D/e:?Release?UploadService:com.cn21.ecloud.netapi.a.m@24817145

11-25?18:17:41.783?26180-26378/com.cn21.ecloud?D/d:?Transfer?Ex

java.io.IOException:?File?descriptor?closed

at?libcore.io.Posix.readBytes(Native?Method)

at?libcore.io.Posix.read(Posix.java:147)

at?libcore.io.BlockGuardOs.read(BlockGuardOs.java:230)

at?libcore.io.IoBridge.read(IoBridge.java:472)

at?java.io.FileInputStream.read(FileInputStream.java:177)

at?java.io.DataInputStream.read(DataInputStream.java:63)

at?java.io.InputStream.read(InputStream.java:162)

at?java.io.DataInputStream.read(DataInputStream.java:59)

at?com.cn21.ecloud.netapi.a.m.a(SourceFile:145)

at?com.cn21.ecloud.f.j.dY(SourceFile:160)

at?com.cn21.android.b.e.dX(SourceFile:52)

at?com.cn21.android.b.d.run(SourceFile:459)

at?com.cn21.android.b.b.dS(SourceFile:316)

at?com.cn21.android.b.b.a(SourceFile:14)

at?com.cn21.android.b.c.run(SourceFile:62)

at?java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)

at?java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)

at?java.lang.Thread.run(Thread.java:818)

11-25?18:17:41.783?26180-26378/com.cn21.ecloud?D/transferLoop:?Transfer?task:20151124_111841.mp4?stopped

報文件無效問題濒析;

檢查文件的讀方面發(fā)現(xiàn)有個getFD(),獲取文件的通道啥纸;進入FileInputStream這個類構(gòu)造方法去發(fā)現(xiàn)這個stream流需要手動關(guān)閉:

[html]view plaincopy

/**

*?Constructs?a?new?{@code?FileInputStream}?that?reads?from?{@code?fd}.

*

*?@param?fd

*????????????the?FileDescriptor?from?which?this?stream?reads.

*?@throws?NullPointerException

*?????????????if?{@code?fd}?is?{@code?null}.

*/

public?FileInputStream(FileDescriptor?fd)?{

if?(fd==?null)?{

throw?new?NullPointerException("fd==?null");

}

this.fd=fd;

this.shouldClose=false;

//?Note?that?we?do?not?call?guard.open?here?because?the

//?FileDescriptor?is?not?owned?by?the?stream.

}

this.shouldClose = false;這個問題有點大号杏,因此需要最后文件上傳完再finally中關(guān)閉之前用RandomAccessFile打開的文件的句柄。

但是這個問題有點怪異斯棒,為什么不混淆時就不會出問題盾致?而在混淆過后才能爆出這個問題?

總結(jié):

最終問題的表面現(xiàn)在也許不是問題發(fā)生的根本原因荣暮;因為最后表現(xiàn)出來的問題可能是上一個問題引發(fā)的庭惜;因此需要往前面走點查查。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末穗酥,一起剝皮案震驚了整個濱河市护赊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌砾跃,老刑警劉巖骏啰,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異抽高,居然都是意外死亡判耕,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門翘骂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來壁熄,“玉大人帚豪,你說我怎么就攤上這事〔萆ィ” “怎么了志鞍?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長方仿。 經(jīng)常有香客問我固棚,道長,這世上最難降的妖魔是什么仙蚜? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任此洲,我火速辦了婚禮,結(jié)果婚禮上委粉,老公的妹妹穿的比我還像新娘呜师。我一直安慰自己,他們只是感情好贾节,可當(dāng)我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布汁汗。 她就那樣靜靜地躺著,像睡著了一般栗涂。 火紅的嫁衣襯著肌膚如雪知牌。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天斤程,我揣著相機與錄音角寸,去河邊找鬼。 笑死忿墅,一個胖子當(dāng)著我的面吹牛扁藕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播疚脐,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼亿柑,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了棍弄?” 一聲冷哼從身側(cè)響起望薄,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎照卦,沒想到半個月后式矫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體乡摹,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡役耕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了聪廉。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瞬痘。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡故慈,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出框全,到底是詐尸還是另有隱情察绷,我是刑警寧澤,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布津辩,位于F島的核電站拆撼,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏喘沿。R本人自食惡果不足惜闸度,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蚜印。 院中可真熱鬧莺禁,春花似錦、人聲如沸窄赋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忆绰。三九已至浩峡,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間错敢,已是汗流浹背红符。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留伐债,地道東北人预侯。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像峰锁,于是被迫代替她去往敵國和親萎馅。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,658評論 2 350

推薦閱讀更多精彩內(nèi)容