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

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

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

android上使用appache httpclient上傳文件時(shí)報(bào)一下錯(cuò)誤:

[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類,實(shí)現(xiàn)進(jìn)度得回調(diào);

問(wèn)題的表現(xiàn):在混淆中,上傳文件時(shí)就會(huì)報(bào)這個(gè)問(wèn)題;不混淆則一直沒(méi)有沒(méi)有問(wèn)題;

解決:

1.一開始被這個(gè)問(wèn)題領(lǐng)向錯(cuò)誤的方向;因?yàn)槭腔煜鰡?wèn)題,不混淆則一直沒(méi)問(wèn)題,所以在查混淆是否導(dǎo)致問(wèn)題這個(gè)方向上:到最后添加了所有的類都不混淆的也不能解決問(wèn)題

-keep class **{*;}

2.查看錯(cuò)誤的log:貌似是NonRepeatableRequestException是不可重讀的問(wèn)題,

用filebody不好替換;

3.用HttpURLConnection替換http client,最后報(bào)錯(cuò)如下:

[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

報(bào)文件無(wú)效問(wèn)題;

檢查文件的讀方面發(fā)現(xiàn)有個(gè)getFD(),獲取文件的通道;進(jìn)入FileInputStream這個(gè)類構(gòu)造方法去發(fā)現(xiàn)這個(gè)stream流需要手動(dòng)關(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;這個(gè)問(wèn)題有點(diǎn)大,因此需要最后文件上傳完再finally中關(guān)閉之前用RandomAccessFile打開的文件的句柄。

但是這個(gè)問(wèn)題有點(diǎn)怪異,為什么不混淆時(shí)就不會(huì)出問(wèn)題?而在混淆過(guò)后才能爆出這個(gè)問(wèn)題?

總結(jié):

最終問(wèn)題的表面現(xiàn)在也許不是問(wèn)題發(fā)生的根本原因;因?yàn)樽詈蟊憩F(xiàn)出來(lái)的問(wèn)題可能是上一個(gè)問(wèn)題引發(fā)的;因此需要往前面走點(diǎn)查查。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容