Как избежать принудительного закрытия с помощью IOException и SocketTimeoutException JSoup? - PullRequest
1 голос
/ 18 августа 2011

Я использую этот код, чтобы получить html-страницу и проанализировать ее

while(doc == null && retry<5){
                retry++;
                try {
                    doc = Jsoup.connect(url).get();
                } catch (IOException e) {
                   Log.e("ReleaseInfo", "JSoup get didnt get a document", e);


                }

Как только документ получен, я использую его, чтобы получить некоторую информацию и проверить ее на нулевое значение.

  overview = doc.select("div#object-overview").last();


                 if(overview != null){

                paragraph = overview.select("p").last();

                        if(paragraph != null){
                              Log.v("Paragraph", paragraph.text());

                        }else{

                            Toast.makeText(releaseInfo.this, "No over view content", Toast.LENGTH_SHORT);
                        }


                        }

                        else{


                        }

                    featureList = doc.select("div.callout-box").last();


                    if(featureList != null){
                        Log.v("OverView", featureList.text());  

Как видите, я ловлю ошибку с помощью оператора журнала.IOException сообщает мне об этом

08-17 12:54:11.535: ERROR/ReleaseInfo(5960): JSoup get didnt get a document
08-17 12:54:11.535: ERROR/ReleaseInfo(5960): java.net.SocketTimeoutException
08-17 12:54:11.535: ERROR/ReleaseInfo(5960):     at org.apache.harmony.luni.net.PlainSocketImpl.read(PlainSocketImpl.java:564)
08-17 12:54:11.535: ERROR/ReleaseInfo(5960):     at org.apache.harmony.luni.net.SocketInputStream.read(SocketInputStream.java:88)
08-17 12:54:11.535: ERROR/ReleaseInfo(5960):     at java.io.InputStream.skip(InputStream.java:258)
08-17 12:54:11.535: ERROR/ReleaseInfo(5960):     at org.apache.harmony.luni.net.SocketInputStream.skip(SocketInputStream.java:93)
08-17 12:54:11.535: ERROR/ReleaseInfo(5960):     at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl$ChunkedInputStream.skipOutstandingChunks(HttpURLConnectionImpl.java:374)

Как я могу защитить свой код от этой ошибки, чтобы не принудительно закрывать его, когда документ не получен?

Также я хотел бы перехватить и ответить наэто исключение, которое вызывает принудительное закрытие моего приложения.

08-17 16:27:29.245: ERROR/ReleaseInfo(8641): JSoup get didnt get a document
08-17 16:27:29.245: ERROR/ReleaseInfo(8641): java.io.IOException: 404 error loading URL http://pc.gamespy.com/web-games/parking-wars-2/
08-17 16:27:29.245: ERROR/ReleaseInfo(8641):     at org.jsoup.helper.HttpConnection$Response.execute(HttpConnection.java:387)
08-17 16:27:29.245: ERROR/ReleaseInfo(8641):     at org.jsoup.helper.HttpConnection$Response.execute(HttpConnection.java:364)
08-17 16:27:29.245: ERROR/ReleaseInfo(8641):     at org.jsoup.helper.HttpConnection.execute(HttpConnection.java:143)
08-17 16:27:29.245: ERROR/ReleaseInfo(8641):     at org.jsoup.helper.HttpConnection.get(HttpConnection.java:132)

1 Ответ

4 голосов
/ 18 августа 2011

Записи журнала, которые вы показываете, указывают, что вы перехватили исключение и распечатали его в журнале как ошибку, как и следовало ожидать.Ни одна из этих записей не должна принудительно закрывать ваше приложение.Есть ли другие записи?Например, если после 5 повторных попыток вы все еще не установили соединение, то «doc» будет равно нулю, а следующая строка вызовет неперехваченное исключение nullPointerException, а затем закроет ваше приложение:

overview = doc.select("div#object-overview").last();
...